Cookie&&Session原理

Cookie原理
基于响应头Set-Cookie和请求头Cookie实现
第一次访问后台完成,服务器new Cookie后response.addCookie(cookie),通过Set-Cookie响应头将cookie带回浏览器,浏览器会保存。
第二次访问后台时,浏览器会通过Cookie请求头传入后台。

Cookie共享问题
一个tomcat下不同项目默认不能访问获得其他项目创建的cookie,但是可以在生产cookie的时候setPath("/")设置虚拟路径为根路径来共享。
不同tomcat间可以通过设置一级域名的方式共享
setDomain(".baidu=.com"),那么tieba.baidu.com和news.baidu.com中cookie可以共享

Session原理:基于Cookie回写jsessionid,确保在同一次会话中使用的同一个session。
第一次访问服务器,服务器会创建session,并创建cookie用于存储jsessionid,回写到浏览器,浏览器不关闭再次访问,会将携带sessionid的cookie通过Cookie请求头发送给服务器,保证使用同一个session。

1.浏览器关闭,服务器开启,两次获取session是否同一个?
默认不是。因为cookie在浏览器关闭就消失了。

  • 如果需要相同,则可以创建Cookie,键为JSESSIONID,设置最大存活时间,让cookie持久化保存。
    Cookie co = new Cookie(“JSESSIONID”,session.getId());
    co.setMaxAge(60*60);
    response.addCookie(co);

2.浏览器不关闭,服务器关闭,两次获取的session是否同一个?
不是。因为服务器关闭session对象被销毁了。
但是要保存数据,可以设置session的存活时间(默认30min,在tomcat的web.xml中配置)并且依赖钝化和活化。

注意:Idea不能测试活化,会把work目录删除再创建,读取不到序列化后的session。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CookieSession都是用来在Web应用中跟踪用户身份和状态的机制,但它们的工作原理有所不同。 1. Cookie工作原理: 当用户访问一个网站时,服务器会在响应中包含一个名为"Set-Cookie"的HTTP头部,其中包含了一些信息,如用户ID、登录状态等。浏览器接收到这个Cookie后,会将其存储在本地,下次用户再访问该网站时,浏览器会自动将Cookie发送到服务器。服务器根据Cookie中的信息来识别用户身份和状态。 2. Session工作原理Session是基于服务器端的机制。当用户首次访问网站时,服务器会为该用户创建一个唯一的Session ID,并将该ID存储在服务器端的内存或数据库中。同时,服务器会将该Session ID发送给浏览器,通常通过一个名为"sessionid"的Cookie。浏览器在后续的请求中会自动携带该Cookie。服务器通过Session ID来查找对应的用户状态和数据。 具体的流程如下: - 用户访问网站时,服务器检查请求中是否包含有效的Session ID。 - 如果没有有效的Session ID,则创建一个新的Session,并生成一个唯一的Session ID。 - 服务器将该Session ID发送给浏览器,并在响应中设置一个名为"sessionid"的Cookie。 - 浏览器接收到Cookie后,存储在本地。 - 在后续的请求中,浏览器会自动将该Cookie发送给服务器。 - 服务器根据Session ID查找对应的Session,并根据需要更新Session的状态和数据。 需要注意的是,Cookie存储在客户端,可以被用户修改或删除;而Session存储在服务器端,对用户是不可见的。此外,为了保护用户数据的安全性,通常会对CookieSession进行加密和签名处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值