我正在使用Java Servlet创建网站,有一个名为LogIn的页面。我希望用户成功填写登录表单后,返回到他们之前访问的页面。如果是从其他页面进行GET或POST请求,这将正常工作,因为之前的页面存储在Referer标头中。但是,当我从用户无法访问的页面重定向(302)到LogIn页面时,Referer标头为空。是否有任何方法可以在用户被重定向到LogIn页面时实现我的目标?
我不会信任referer头,因为它是否被发送取决于浏览器。相反,根据当前请求的URI自己提供。
response.sendRedirect("login?from=" + URLEncoder.encode(request.getRequestURI(), "UTF-8"));
然后在登录表单中
<form action="login" method="post">
<input type="text" name="username">
<input type="password" name="password">
<input type="hidden" name="from" value="${param.from}">
<input type="submit">
</form>
然后在登录操作中
User user = userDAO.find(username, password);
if (user != null) {
session.setAttribute("user", user);
response.sendRedirect(request.getParameter("from"));
} else {
request.setAttribute("error", "Unknown login");
request.getRequestDispatcher("/WEB-INF/login.jsp").forward(request, response);
}
session.setAttribute("from", request.getRequestURI());
response.sendRedirect("login");
然后在登录操作中
response.sendRedirect((String) session.getAttribute("from"));
session.removeAttribute("from");
你可能想要将当前页面作为GET参数附加,例如http://yoursite.com/login?redir=/topics,这样在您的认证servlet中,如果用户没有适当的凭据,只需获取当前URI,附加到登录URL并重定向即可。