Cookie Session Token

存储位置:

客户端(浏览器)中的 Cookie。
工作原理:

登录:用户提交登录表单,服务器验证凭证(如用户名和密码 )。

设置 Cookie:服务器在响应中设置一个包含会话 ID 的 Cookie。

验证请求:浏览器在后续请求中自动包含这个 Cookie,服务器根据会话 ID 验证用户身份。

登出:用户请求登出,服务器销毁会话,并删除 Cookie。

缺点:

对于跨域请求,配置比较复杂(需要设置 CORS)。

易受 XSS 攻击,需要设置 HttpOnly 和 Secure 标志提高安全性。

Session (会话)

存储位置:

服务器端

复制代码
Session是存储于服务器端的特殊对象,
服务器会为每一个游览器(客户端)创建一个唯一的session。
这个session是服务器端共享,每个游览器(客户端)独享的。

在HTTP请求中往往会携带一个cookie,这个cookie的名字是JSESSIONID这个JSESSIONID表示的就是session的id,这个是由服务器创建的,并且是唯一的。服务器在使用session时,会根据JSESSIONID来进行不同操作。

工作原理:

登录:用户提交登录表单,服务器验证凭证。

创建会话:服务器创建一个新的会话,分配唯一的 Session ID ,存储在服务器端的会话存储中。

设置 Cookie:服务器在响应中设置包含 Session ID 的 Cookie。

验证请求:浏览器在后续请求中自动包含这个 Cookie,服务器根据 Session ID 验证用户身份

登出:用户请求登出,服务器销毁会话,并删除 Cookie。

优点:

数据存储在服务器端,更安全。

能存储复杂和大量的数据。

缺点:

需要服务器资源,可能影响性能。
跨服务器的会话管理比较复杂,需要使用分布式会话管理方案。

Token(令牌)

Token是"令牌"的意思。

Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌。

当第一次登录后,服务器生成一个Token便将此Token返回给客户端,以后客户端只需带上这个Token前来请求数据即可,无需再次带上用户名和密码。

存储位置:

客户端,通常在 HTTP 头、LocalStorage 或 SessionStorage 中。

工作原理:

登录:用户提交登录表单,服务器验证凭证。

生成令牌:服务器生成一个加密的令牌(如 JWT) ,包含用户身份信息和有效期限。

返回令牌:服务器在响应中返回令牌,客户端存储令牌。

验证请求:客户端在后续请求中将令牌包含在 HTTP 头中,服务器验证令牌的有效性和签名。

刷新令牌:令牌过期时,客户端可以使用刷新令牌机制获取新的令牌。

优点:

无状态,易于扩展和跨服务器共享。

可以使用 JSON Web Token(JWT)标准,便于传输和解析。

缺点:

需要正确实现加密和签名,避免安全漏洞。

令牌泄露后可能导致安全风险,需要有效的令牌失效机制。

示例:

复制代码
POST /login
Content-Type: application/json

{
  "username": "user",
  "password": "password"
}

HTTP/1.1 200 OK
Content-Type: application/json

{
  "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}

GET /protected
Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...

总结对比

Cookie:使用简单,但安全性较低,适合小规模应用。

Session:安全性高,适合复杂应用,但需要管理服务器资源和会话存储。

Token:无状态、可扩展,适合分布式系统和跨域请求,但需要处理加密和令牌管理。

相关推荐
知乎的哥廷根数学学派4 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
且去填词5 小时前
DeepSeek :基于 Schema 推理与自愈机制的智能 ETL
数据仓库·人工智能·python·语言模型·etl·schema·deepseek
人工干智能5 小时前
OpenAI Assistants API 中 client.beta.threads.messages.create方法,兼谈一星*和两星**解包
python·llm
databook5 小时前
当条形图遇上极坐标:径向与圆形条形图的视觉革命
python·数据分析·数据可视化
阿部多瑞 ABU5 小时前
`chenmo` —— 可编程元叙事引擎 V2.3+
linux·人工智能·python·ai写作
acanab6 小时前
VScode python插件
ide·vscode·python
知乎的哥廷根数学学派6 小时前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
WangYaolove13147 小时前
Python基于大数据的电影市场预测分析(源码+文档)
python·django·毕业设计·源码
知乎的哥廷根数学学派7 小时前
基于自适应多尺度小波核编码与注意力增强的脉冲神经网络机械故障诊断(Pytorch)
人工智能·pytorch·python·深度学习·神经网络·机器学习
cnxy1888 小时前
Python爬虫进阶:反爬虫策略与Selenium自动化完整指南
爬虫·python·selenium