我正在尝试从 HTTPSession 注销并将用户重定向到登录页面。
下面是我完整的 Http servlet 代码。
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class LogoutServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
super.doGet(req, resp);
processRequest(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
super.doPost(req, resp);
processRequest(req, resp);
}
private void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
final HttpSession session = request.getSession(false);
if (session != null)
{
session.invalidate();
}
response.sendRedirect("/login.html");
//getServletContext().getRequestDispatcher("/login.html").forward(request, response);
}
}
但得到以下异常:
java.lang.IllegalStateException: Cannot forward after response has been committed
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:339)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329)
at com.controller.LogoutServlet.processRequest(LogoutServlet.java:41)