【java入门到放弃】Session和JWT

概述

cookie传到后端会解析成Map<String, String>

实际开发中通常只存"少量关键信息(比如一个 token)"

Session 在使用上类似 Map,通过 key-value 存储数据

Session一般存用户id、权限信息等。

一般情况下,讲Session序列化成json,以String类型,存到redis

分布式

JWT是无状态的,支持分布式

Session要支持分布式,需要存到redis里

单点登录

每一次登录成功,需要生成一个全新的 唯一的 sessionId

还需要把 userId 和 sessionId 存入redis

jwt的话,可以加入签发时间生成token,这样同一个用户,每次登录都是不同的token

也是一样,把 userId 和 token 存入redis。

安全

JWT 可以存储在 Cookie 或 localStorage 中。将 JWT 存在 Cookie 中可以利用 HttpOnly、Secure、SameSite 等属性提高安全性,但需要防范 CSRF 攻击;而存储在 localStorage 中可以避免 CSRF,但需要防范 XSS 攻击。因此,安全性取决于整体设计,而不是存储位置。

shell 复制代码
HttpOnly = true   (JS 读不到)
Secure   = true   (只走 HTTPS)
SameSite = Strict / Lax(防 CSRF)
相关推荐
亦暖筑序43 分钟前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏1 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev3 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还18 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩19 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia19 小时前
Mybatis的日志输入
java
亦暖筑序21 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试