我有一个JSP,Servlet,Hibernate应用程序。在这个应用程序中,我有一个非常奇怪的问题。也就是说,如果会话过期(换句话说"超时"),当用户点击链接时,页面将被重定向到索引页面,但之后用户无法登录进入并访问他点击的最后一个链接。我将在下面逐步描述它。
点击链接访问 / Visa (从链接可用的任何地方) 。链接是链接到其路径的位置,如
签证?idEmployee = 1
现在问题了。用户被重定向回索引页面。
我有Filter
来监控会话是否为null
以及所需的会话属性是否不是null
。如果请求不满足上述2个条件,则请求将被发送回索引。
过滤器代码如下。
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package Filter;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
/**
*
* @author user
*/
public class AuthenticationFilter_Level1 implements Filter
{
@Override
public void init(FilterConfig filterConfig) throws ServletException
{
}
@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException
{
HttpServletRequest request = (HttpServletRequest)req;
HttpServletResponse response = (HttpServletResponse)res;
HttpSession session = request.getSession(false);
Integer attribute = null;
if(session!=null && session.getAttribute("idSubUser")!=null)
{
chain.doFilter(req, res);
}
else
{
//response.sendRedirect("index.html");
RequestDispatcher dispatch = request.getRequestDispatcher("index.html");
dispatch.forward(req, res);
}
}
@Override
public void destroy()
{
}
}
在web.xml中,我已经将servlet中的过滤器添加到servlet中,如下所示。
<filter-mapping>
<filter-name>AuthenticationFilter_Level1</filter-name>
<url-pattern>/RegSrvlt</url-pattern>
<url-pattern>/AdminPopulateSrvlt</url-pattern>
<url-pattern>/AgentPopulate</url-pattern>
......
过滤器会话超时配置如下。
<session-config>
<session-timeout>
1
</session-timeout>
</session-config>
那么,这里发生了什么?
更新
发生上述错误时,即使重定向,网址实际上看起来像http://localhost:8080/xxx/Visa?idEmployee=1
!
更新
我发现这与过滤器无关。什么可以做到这一点?
答案 0 :(得分:1)
else
{
if (session != null) {
session.invalidate();
}
...
并检查创建会话的位置(即公共JSP / servlet)。
答案 1 :(得分:0)
另一个可能的原因可能是浏览器中的缓存问题:
/Visa
index.html
=&gt;浏览器缓存它,因为它是一个不错的html页面/Visa
链接index.html
页面如何确认:
如何解决:
index.html
之前不缓存页面 - 应该可以,但我不知道正确的标头配置index.html
。这样浏览器就不应该为index.html
网址/Visa