瑞吉外卖中关于短信校验代码的Session问题

关于短信校验代码中HttpSession

由于涉及到阿里云的短信服务,这里改成直接从服务端查看验证码

代码中有一个关于session的问题:

java 复制代码
session.setAttribute("user",user.getId());

这一段代码中为什么session.setAttribute("user",user.getId())可以直接保存到前端浏览器的session,不是说session是保存到服务器吗?

核心概念澄清

HttpSession 数据确实只存储在服务器端(内存/Redis/数据库等)

浏览器永远不会直接获取或存储 Session 数据,它只保存一个 Session ID(通常通过 Cookie)

代码执行流程详解

session.setAttribute("user", user.getId())

将用户ID 存储在服务器的 Session 对象中(键为 "user",值为用户ID)

此时没有任何数据发送到浏览器!

Session ID 的传递机制

当第一次调用 request.getSession() 时,服务器会:

创建一个唯一的 JSESSIONID(如 ABC123)

在响应头中通过 Set-Cookie: JSESSIONID=ABC123 告诉浏览器保存此ID

http 复制代码
HTTP/1.1 200 OK
Set-Cookie: JSESSIONID=ABC123; Path=/; HttpOnly

浏览器后续请求会自动携带此Cookie:

http 复制代码
GET /api/userinfo HTTP/1.1
Cookie: JSESSIONID=ABC123

服务器如何关联数据

当浏览器携带 JSESSIONID=ABC123 访问时:

服务器通过 ABC123 找到对应的 HttpSession 对象

然后从该对象中读取 getAttribute("user") 获取用户ID

为什么看起来像是"保存到前端"?

错觉来源:因为浏览器保存了 JSESSIONID Cookie,使得后续请求能自动关联到服务器的 Session 数据

关键结论

session.setAttribute() 只修改服务器端数据

浏览器仅持有 JSESSIONID(无实际用户数据)

如果浏览器禁用Cookie,Session 机制会失效(除非改用URL重写)

相关推荐
勇往直前plus1 分钟前
Milvus快速入门以及用 Java 操作 Milvus
java·spring boot·embedding·milvus
失散132 分钟前
分布式专题——2 深入理解Redis线程模型
java·数据库·redis·分布式·架构
王伯安呢31 分钟前
Java开发环境配置入门指南
java·开发语言·jvm·eclipse·环境搭建·新手
rockmelodies1 小时前
Java安全体系深度研究:技术演进与攻防实践
java·开发语言·安全
代码栈上的思考1 小时前
深入解析 Java 内存可见性问题:从现象到 volatile 解决方案
java·开发语言
切糕师学AI1 小时前
如何建立针对 .NET Core web 程序的线程池的长期监控
java·前端·.netcore
零千叶2 小时前
【面试】AI大模型应用原理面试题
java·设计模式·面试
坐吃山猪7 小时前
SpringBoot01-配置文件
java·开发语言
我叫汪枫7 小时前
《Java餐厅的待客之道:BIO, NIO, AIO三种服务模式的进化》
java·开发语言·nio
yaoxtao7 小时前
java.nio.file.InvalidPathException异常
java·linux·ubuntu