前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >重写request设置自定义超时

重写request设置自定义超时

作者头像
用户1418372
发布2018-09-13 10:21:00
1.4K0
发布2018-09-13 10:21:00
举报

主要继承HttpServletRequestWrapper后取得对应的session后进行自定义业务处理

public class SessionInvalidationFilter implements Filter {

    private static final Logger LOGGER = Logger.getLogger(SessionInvalidationFilter.class);
    private static final String LAST_ACCESS_SESSION_ATTR = "lastAccessTime";

    private static final long SESSION_TIMEOUT = 1000 * 60 * 20; // 20 minutes
    private static final String IGNORE_ACCESS_URI = "/user/checkUserLoginStatus";

    @Override
    public void init(FilterConfig arg0) throws ServletException {
    }

    @Override
    public void destroy() {
    }

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        // Cast to HTTP request and response
        HttpServletRequest httpRequest = (HttpServletRequest) request;
        HttpServletResponse httpResponse = (HttpServletResponse) response;
        // Check if we are handling standard request
        LOGGER.info("请求地址:"+httpRequest.getServletPath());
        if (!IGNORE_ACCESS_URI.equals(httpRequest.getServletPath())) {
            chain.doFilter(new SessionAccessAwareRequest(httpRequest), response);
            return;
        }
        // Now we can handle the special case of non-tracked request
        boolean expired = false;
        HttpSession session = httpRequest.getSession(false);
        if (session == null) {
            // No session means the AJAX contained no or incorrect JSESSIONID
            expired = true;
        } else {
            Long lastAccessTime = (Long) session.getAttribute(LAST_ACCESS_SESSION_ATTR);
            if (lastAccessTime == null || lastAccessTime + SESSION_TIMEOUT < System.currentTimeMillis()) {
                LOGGER.info("设置session失效"+timeOut);
                session.invalidate(); // Invalidate manually
                expired = true;
            }
        }
        // Handle error or process normally
        if (expired) {
            Map<String,Object> result = new HashMap<String,Object>();
            //返回302状态码,跳转首页
            result.put("status", 302);
            result.put("message", "会话超时,请重新登录!");
            result.put("success", false);
            httpResponse.setContentType("application/json;charset=utf-8");
            httpResponse.getWriter().println(JSONObject.toJSONString(result));
            httpResponse.flushBuffer();
            httpResponse.getWriter().close();
        } else {
            chain.doFilter(request, response);
        }
    }

    private static class SessionAccessAwareRequest extends HttpServletRequestWrapper {

        public SessionAccessAwareRequest(HttpServletRequest request) {
            super(request);
        }

        @Override
        public HttpSession getSession() {
            return getSession(true);
        }

        @Override
        public HttpSession getSession(boolean create) {
            HttpSession session = super.getSession(create);
            if (session != null) {
                session.setAttribute(LAST_ACCESS_SESSION_ATTR, System.currentTimeMillis());
            }
            return session;
        }

    }

}

将过滤器加入web xml

<filter>
        <filter-name>SessionInvalidationFilter</filter-name>
        <filter-class>xx.xx.filter.SessionInvalidationFilter</filter-class>
    </filter>

关于spring 国际化

session 国际化

url国际化

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.07.03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 主要继承HttpServletRequestWrapper后取得对应的session后进行自定义业务处理
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档