admin管理员组文章数量:1794759
Spring MVC中jsessionid所引起的问题 和解决
转自:blog.csdn/seakingwy/article/details/1933687
jsessionid所引起的问题在Spring MVC当使用RedirectView或者"redirect:"前缀来做重定向时,Spring MVC最后会调用:response.sendRedirect(response.encodeRedirectURL(url));对于IE来说,打开一个新的浏览器窗口,第一次访问服务器时,encodeRedirectURL()会在url后面附加上一段jsessionid,如果初始的url为"www.sina",最终得到的url为"www.sina;jsessionid=2jcligmgi6fh"。这是典型的Java做事的方式,其他语言的服务器端平台并不会这样做。这个jsessionid很多时候会引起严重的问题,例如,如果你使用上述带有jsessionid的url直接访问新浪的网站,IE会向你报告:找不到服务器。解决方法:1. 不通过Spring MVC做重定向,自己直接调用:response.sendRedirect(url);return null; //告诉Spring MVC我已经完成了处理2. 修改Spring MVC的代码,将:response.sendRedirect(response.encodeRedirectURL(url));改为:response.sendRedirect(url);3. encodeRedirectURL()仅在无法确定浏览器是否支持cookie的时候才会在url后面附加上jsessionid,如果它能找到一个jsessionid的cookie,它就认为浏览器是支持cookie的。因此可以自己创建一个jsessionid的cookie来欺骗encodeRedirectURL()。Cookie cookie = new Cookie("jsessionid", "2jcligmgi6fh");cookie.setMaxAge(Integer.MAX_VALUE);response.addCookie(cookie);然后再调用Spring MVC的重定向功能就没有问题了:return new ModelAndView("redirect:"+url);无疑,这里最好的方法是第3种方法。
转向相同的域,因为之前服务器已经设置了jsessionid这个cookie,并且可以得到这个cookie,因此就不必像上面第一次那样采用url重写的方式,url后面不会附加上jsessionid。因此当你的应用只会转向相同的域时,直接使用Spring MVC的重定向(实际上是最后使用encodeRedirectURL())不会有任何问题。相关资料:Spring MVC RedirectView appends jsessionid:robobruin.blogspot/2005/12/spring-mvc-redirectview-appends.htmlJSESSIONID considered harmful:randomcoder/articles/jsessionid-considered-harmfulCookie和会话状态的工作原理及Cookie欺骗|Cookie,会话状态,Cookie欺骗:www.yuanma/data/2006/0908/article_1489.htm
本文标签: springMVCjsessionid
版权声明:本文标题:Spring MVC中jsessionid所引起的问题 和解决 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686616752a86658.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论