admin管理员组文章数量:1026989
当浏览器执行
当浏览器执行request.getSession()时,浏览器会检测是否有session存在,如果没有就创建一个,有就返回当前这个。
request.getSession(false);与上面不同的是,如果有就返回当前这个Session,没有就返回null。
当session创建时,会向浏览器发送一个没有设置有效时间带有自己id的cookie。
浏览器带着这个cookie访问这个网站时,会告诉servlet该去找那个session。由于这个cookie没有设置有效时间,所以浏览器关闭,这个cookie也就死了。
在打开浏览器servlet就不知道找那个session了,但是session还是存在的。
所以只需重写这个cookie就行了。
HttpSession session = request.getSession();
session.setAttribute("user", user);
String sessionid = session.getId(); //获取sessionid
Cookie cookie = new Cookie("JSESSIONID", sessionid); //new一个cookie,cookie的名字是JSESSIONID跟带id的cookie一样
cookie.setPath(request.getContextPath()); //设置cookie应用范围。getContextPath是获取当前项目的名字。
cookie.setMaxAge(60000); //设置有效时间
response.addCookie(cookie);//用这个cookie把带id的cookie覆盖掉
当浏览器执行
当浏览器执行request.getSession()时,浏览器会检测是否有session存在,如果没有就创建一个,有就返回当前这个。
request.getSession(false);与上面不同的是,如果有就返回当前这个Session,没有就返回null。
当session创建时,会向浏览器发送一个没有设置有效时间带有自己id的cookie。
浏览器带着这个cookie访问这个网站时,会告诉servlet该去找那个session。由于这个cookie没有设置有效时间,所以浏览器关闭,这个cookie也就死了。
在打开浏览器servlet就不知道找那个session了,但是session还是存在的。
所以只需重写这个cookie就行了。
HttpSession session = request.getSession();
session.setAttribute("user", user);
String sessionid = session.getId(); //获取sessionid
Cookie cookie = new Cookie("JSESSIONID", sessionid); //new一个cookie,cookie的名字是JSESSIONID跟带id的cookie一样
cookie.setPath(request.getContextPath()); //设置cookie应用范围。getContextPath是获取当前项目的名字。
cookie.setMaxAge(60000); //设置有效时间
response.addCookie(cookie);//用这个cookie把带id的cookie覆盖掉
版权声明:本文标题:浏览器从新打开session失效解决方法 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://it.en369.cn/jiaocheng/1737921912a1521451.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论