浏览器从新打开session失效解决方法

当浏览器执行

当浏览器执行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覆盖掉

 

 

转载于:https://www.cnblogs.com/sjyzz/p/6763200.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值