今天遇到了一个很奇怪的问题, 我在tomcat过滤器 中, 对请求过来的静态资源及html页面做了forword转发操作,核心代码如下:
private void redirectMobile(HttpServletRequest request, ServletRequest req, ServletResponse res, String requestPath) throws ServletException, IOException { ServletContext servletContext = request.getSession().getServletContext(); String queryString = (request.getQueryString() == null ? "" : "" + request.getQueryString()); RequestDispatcher rd = servletContext.getRequestDispatcher("/page/mobile" + requestPath+"?"+queryString); rd.forward(req, res); }
然而出现了一个问题, 线下跑得好好的, 放到线上之后, 用户的登入信息就无法维持了, 经过排查, 发现只要是通过转发的请求 返回来的 response 都重新 设置了sessionid,导致session丢失了,如下:
十分苦恼为什么会出现这样的情况, 线下是好的,线上就不行
后来想到可能是 memcached 的问题,于是在线上取消memcached配置测试一下 果然就好了,然后开始排查问题
最后在过滤器核心代码中发现了一个不起眼的问题, 我在获取 servletContext时, 是通过 request.getSession()去获取的,但是request可以直接获取servletContext,于是 改成request.getServletContext() ,如下:
private void redirectMobile(HttpServletRequest request, ServletRequest req, ServletResponse res, String requestPath) throws ServletException, IOException { ServletContext servletContext = request.getServletContext(); String queryString = (request.getQueryString() == null ? "" : "" + request.getQueryString()); RequestDispatcher rd = servletContext.getRequestDispatcher("/page/mobile" + requestPath+"?"+queryString); rd.forward(req, res); }
重新放到线上测试, sessionid不变了。
这是一个不起眼的问题。希望能帮到遇到相同问题的同学