session、cookie、Jwt-token

cookie:

cookie是服务器发送到用户浏览器并保存的小型文本数据,浏览器会在后续请求中自动携带这些数据给同一个服务器。

它的样子:

HTTP响应头中设置Cookie

Set-Cookie: session_id=abc123; Path=/; Max-Age=3600; HttpOnly

浏览器下次请求时自动带上

Cookie: session_id=abc123; theme=dark

cookie的创建过程:

首先是用户访问网站,然后服务器响应时设置cookie,浏览器再保存cookie,用户再次访问的时候会自动带上cookie,服务器会通过读取cookie识别用户。

cookie的属性和参数:

|----------------|---------|-------------------------|
| 属性 | 说明 | 示例 |
| Name/Value | 名称和值 | username=张三 |
| Domain​ | 生效域名 | .example.com(子域名共享) |
| ​Path | 生效路径 | /admin(仅/admin路径下有效) |
| Expires/MaxAge | 过期时间 | MaxAge=86400(1天) |
| HttpOnly | 禁止JS访问 | 防XSS攻击 |
| Secure | 仅Http传输 | 防止中间人窃取 |
| SameSite | 跨站限制 | 防CSRF攻击 |

session:

Session是服务器端的用户状态存储机制 。服务器为每个用户创建一个唯一的Session,但Session ID通常通过Cookie传递给客户端

工作原理:

用户登录,服务器创建session,生成唯一ID,Session ID通过Cookie发送给浏览器,浏览器保存Session ID,下次请求自动带上Session ID,服务器用Session ID查找对应的Session数据。

Token:

Token是自包含的、可验证的身份凭证 ,通常是JSON格式,经过数字签名,服务器不需要存储会话状态

JWT(JSON Web Token)结构:
Go 复制代码
Header.Payload.Signature

实际的Token示例:

Go 复制代码
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.           # Header
eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.  # Payload
SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c     # Signature
JWT工作流程:

用户登录,服务器验证凭证,生成JWT Token(包含用户信息和签名),返回Token给客户端,客户端存储Token(LocalStorage/Cookie),每次请求在Authorization头中携带Token,服务器验证签名,提取用户信息,返回响应。

相关推荐
悟空聊架构4 分钟前
GStack的26种专家角色,真正实现一人成军!
后端
counting money8 分钟前
Spring框架基础(依赖注入-半注解形式)
java·后端·spring
SmartRadio8 分钟前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信 (采用Arduino代码框架)
开发语言·智能手机·esp32·长距离wifi
Code_Artist11 分钟前
一天之内我让 AI 用 Netty 造了一个最小可用的 MVC 框架:体验一下造轮子的快感😅!
后端·netty·ai编程
也许明天y18 分钟前
LangChain4j + Spring Boot 多智能体协调架构原理深度解析
spring boot·后端·agent
njsgcs18 分钟前
solidworks自动标注折弯4 无向图 c#
开发语言·c#·solidworks
c++之路31 分钟前
C++ 多线程
开发语言·c++
CHANG_THE_WORLD36 分钟前
<Fluent Python > Unicode 文本与字节
开发语言·python
AI人工智能+电脑小能手41 分钟前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
凯瑟琳.奥古斯特42 分钟前
Bootstrap快速上手指南
开发语言·前端·css·bootstrap·html