【问题标题】:Why I can't access the servlet after the session time out?为什么会话超时后我无法访问 servlet?
【发布时间】:2015-07-14 02:18:06
【问题描述】:

我有一个 JSP、Servlet、Hibernate 应用程序。在这个应用程序中,我有一个非常奇怪的问题。也就是说,如果会话过期(即“超时”)并且当用户单击链接时,页面将被重定向到索引页面,但之后用户无法登录并访问最后一个他点击的链接。我将在下面一步一步地描述它。

  1. 用户登录到应用程序。会话被创建。
  2. 他访问路径 /Passport
  3. 用户现在空闲,会话已过期。
  4. 用户回来点击链接访问/Visa。由于会话现在空闲,用户将被重定向到索引页面。
  5. 用户登录。
  6. 点击链接访问/Visa(从任何有链接的地方) .该链接是它链接到其路径的位置,例如

    Visa?idEmployee=1

  7. 现在的问题。用户被重定向回索引页面。

我有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>

那么,这里发生了什么?

更新

发生上述错误时,即使重定向,URL 实际上看起来像http://localhost:8080/xxx/Visa?idEmployee=1

更新

我发现这与过滤器无关。那有什么办法呢?

【问题讨论】:

  • 会话属性 idSubUser 在哪里设置?是否有可能解析为 null,因此用户被重定向到 index.html?

标签: java session servlets tomcat7 servlet-filters


【解决方案1】:
    else
    {
        if (session != null) {
            session.invalidate();
        }
        ...

并检查创建会话的位置(即公共 JSP/servlet)。

【讨论】:

  • 您可以尝试发送重定向,而不是转发。
  • forward 实际上可以很好地包含当前的HttpRequest 对象。这实际上可能是挽救他的处境的方法:将数据作为请求的一部分,而不是会话!
  • 登录时,一定要新建一个Session,并设置"idSubUser"Session属性。
【解决方案2】:

另一个可能的原因可能是浏览器中的缓存问题:

  • 客户端浏览器请求/Visa
  • 服务器发送index.html => 浏览器缓存它,因为它是一个不错的 html 页面
  • ...
  • 在同一个浏览器会话中,用户点击了/Visa链接
  • 甚至无需向服务器询问任何内容,浏览器就会显示缓存的 index.html 页面

如何确认:

  • 服务器端,通过查看服务器日志来查看页面是否被实际请求
  • 客户端或服务器端通过使用网络间谍(例如wireshark)并查看是否发送了请求
  • 客户端清空缓存而不是 cookie

如何解决:

  • 尝试添加一个标题,要求在转发到index.html 之前不要缓存页面 - 应该可以,但我不完全知道正确的标题配置
  • 用重定向替换转发到index.html。这样浏览器就不应该为/Visa URL 缓存index.html

【讨论】:

  • 感谢您的回复。关于redirection,你的意思是response.sendRedirect("index.html");?它也没有用!
  • 我注意到过滤器中没有错误。每当请求重定向时,我都会打印一条消息,当错误发生时,什么都没有打印!
  • @JustCause:您必须先清理浏览器缓存,然后再使用sendRedirect 重试,以确保它不是由先前的缓存引起的。
猜你喜欢
  • 1970-01-01
  • 2015-05-22
  • 1970-01-01
  • 2011-05-06
  • 1970-01-01
  • 2013-09-06
  • 1970-01-01
  • 2015-01-11
  • 2014-04-06
相关资源
最近更新 更多