【JavaEE】-- Cookie &&Session

HTTP协议自身是属于"无状态"协议。

无状态:默认情况下HTTP协议的客户端与服务器之间的这次通信,和下次通信之间没有直接关系。

但是在实际开发中,我们很多时候是需要知道请求之间的关联关系的,比如:保存登陆状态。

上图中的"令牌",通常就存储在Cookie字段中。

2. Session

会话:对话。

在计算机领域中,会话是一个客户端与服务器之间的不间断的请求相应。

当一个未知的客户向Web应用程序发送第一个请求时,就开启了一个会话;当客户结束会话或服务器在一个时限内没有接收到客户的任何请求时,会话就结束了。

服务器在同一时刻接收到的请求时很多的,对于同一个客户向服务器发送的请求,我们希望服务器能够识别出请求来自于同一个客户。

那么就需要在服务器这边记录每个会话以及用户的信息的对应关系。

Session是服务器为了保存用户信息而创建的一个特殊的对象。


session的本质

Session 的本质就是一个哈希表,这个哈希表中存储了一些键值对结构。

key:SessionID;

Value:用户信息。

SessionId是由服务器生成的一个唯一性字段;站在登陆流程上来看,也可以将这个唯一性字符串称为token.


  1. 当用户登陆时,服务器在Session中新增一个新的记录,并把sessionId返回给客户端(通过HTTP相应中的Set-Cookie字段返回)。
  2. 客户端后续再给服务器发送请求的时候,需要再请求中带上sessionId(通过HTTP请求中的Cookie字段)。
  3. 服务器收到请求之后,根据请求中的SessionId在Session信息中获取到对应的用户信息,再进行后续操作,找不到则重新创建Session,并把SessionId返回。

注意: session默认时保存再内存中的,如果重启服务器则Session数据就会丢失。

Cookie是客户端保存用户信息的一种机制.Session是服务器端保存用户信息的一种机制.

Cookie 和 Session之间主要是通过 Sessionld 关联起来的, Sessionld 是 Cookie 和 Session 之间的桥梁。

Cookie 和 Session 经常会在一起配合使用.但是不是必须配合.

  1. 完全可以用Cookie来保存一些数据在客户端.这些数据不一定是用户身份信息,也不一定是Sessionld。

  2. Session 中的sessionld 也不需要非得通过Cookie/Set-Cookie 传递,比如通过URL传递.

相关推荐
Leinwin4 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
薛定谔的悦4 小时前
MQTT通信协议业务层实现的完整开发流程
java·后端·mqtt·struts
enjoy嚣士5 小时前
springboot之Exel工具类
java·spring boot·后端·easyexcel·excel工具类
罗超驿5 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
盐水冰6 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
凸头6 小时前
CompletableFuture 与 Future 对比与实战示例
java·开发语言
wuqingshun3141596 小时前
线程安全需要保证几个基本特征
java·开发语言·jvm
努力也学不会java6 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
攒了一袋星辰6 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
小涛不学习6 小时前
Spring Boot 详解(从入门到原理)
java·spring boot·后端