Cookie Session Token

Cookie (小型文本文件)

存储位置:

客户端(浏览器)中的 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:无状态、可扩展,适合分布式系统和跨域请求,但需要处理加密和令牌管理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/49258.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Win10环境将Docker部署到非系统盘

Win10环境将Docker部署到非系统盘 目录 Win10环境将Docker部署到非系统盘 一、Docker官网客户端Docker Hub下载 二、windows环境的安装 三、正确的迁移步骤 3.1、确保你的系统分区至少3G的剩余空间; 3.2、默认方式安装Docker hub; 3.3、打开Dock…

切换IP地址如何实现?

随着互联网的发展和普及,我们日常生活中的各种操作和通讯越来越依赖互联网。互联网上存在的一些问题和限制使得更换IP地址成为必要的步骤。下面我们将探讨在互联网业务中,需要更换IP地址的原因与方法。 一、IP轮换的应用 解决访问限制:解决访…

Java语言程序设计——篇五(1)

数组 概述数组定义实例展示实战演练 二维数组定义数组元素的使用数组初始化器实战演练:矩阵计算 💫不规则二维数组实战演练:杨辉三角形 概述 ⚡️数组是相同数据类型的元素集合。各元素是有先后顺序的,它们在内存中按照这个先后顺…

分类预测 | Matlab实现WOA-CNN-SVM鲸鱼算法优化卷积支持向量机分类预测

分类预测 | Matlab实现WOA-CNN-SVM鲸鱼算法优化卷积支持向量机分类预测 目录 分类预测 | Matlab实现WOA-CNN-SVM鲸鱼算法优化卷积支持向量机分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现WOA-CNN-SVM鲸鱼算法优化卷积支持向量机分类预测&#xff0…

[排序]hoare快速排序

今天我们继续来讲排序部分,顾名思义,快速排序是一种特别高效的排序方法,在C语言中qsort函数,底层便是用快排所实现的,快排适用于各个项目中,特别的实用,下面我们就由浅入深的全面刨析快速排序。…

visio保存一部分图/emf图片打开很模糊/emf插入到word或ppt中很模糊

本文主要解决三个问题 visio保存一部分图 需求描述:在一个visio文件中画了很多个图,但我只想把其中一部分保存成某种图片格式,比如jpg emf png之类的,以便做后续的处理。 方法:超级容易。 选中希望保存的这部分图&…

基于上下文的自适应二进制算术编码 CABAC 熵编码介绍

介绍 CABAC(Context-Based Adaptive Binary Arithmetic Coding,基于上下文的自适应二进制算术编码)是H.265/HEVC视频编码标准中使用的一种高效的熵编码技术。其核心原理是将自适应二进制算术编码与上下文模型相结合,以实现对视频…

630-基于PCIe的高速模拟AD采集卡

一、产品概述 基于PCIe的一款分布式高速数据采集系统,实现多路AD的数据采集,并通过PCIe传输到存储计算服务器,实现信号的分析、存储。 产品固化FPGA逻辑,适配2路1Gsps/2路2Gsps采集,实现PCIe的触发采集&#xf…

vue3前端开发-小兔鲜项目-使用逻辑函数拆分业务模块

vue3前端开发-小兔鲜项目-使用逻辑函数拆分业务模块!其实就是把一些单独的业务代码组成一个js文件。抽离出去后,方便后面的维护。 如图,在一级分类下面新建一个文件夹。composables里面新建2个js文件。 分别封装之前的分类,和ban…

[Spring] Spring日志

🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…

AI在候选人评估中的作用:精准筛选与HR决策的助力

一、引言 随着科技的迅猛发展,人工智能(AI)技术已逐渐渗透到各个行业和领域,人力资源管理(HRM)亦不例外。在候选人评估的环节中,AI技术以其高效、精准的特性,正在逐步改变着传统的招…

深度学习 —— 个人学习笔记6(权重衰减)

声明 本文章为个人学习使用,版面观感若有不适请谅解,文中知识仅代表个人观点,若出现错误,欢迎各位批评指正。 十三、权重衰减 使用以下公式为例做演示: y 0.05 ∑ i 1 d 0.01 x i ε w h e r e ε ~ N…

从PyTorch官方的一篇教程说开去(4 - Q-table来源及解决问题实例)

偷个懒,代码来自比很久之前看的书,当时还在用gym,我做了微调以升级到gymnasium当前版本,确保可以正常演示。如果小伙伴或者原作者看到了麻烦提一下,我好备注一下出处。 您的进步和反馈是我最大的动力,小伙…

语音识别 语音识别项目相关笔记内容

语音识别 语音识别项目相关笔记内容 语音识别应用范畴语音识别框架语音基本操作使用scipy.io.wavfile读取wav音频文件获取采样率、长度、通道数使用numpy读取pcm格式音频文件读取wav音频文件,并绘制图像读取双声道的wav音频文件,分别绘制不同声道的波形图读取一个采样率为16k…

【Docker】Docker Desktop - WSL update failed

问题描述 Windows上安装完成docker desktop之后,第一次启动失败,提示:WSL update failed 解决方案 打开Windows PowerShell 手动执行: wsl --set-default-version 2 wsl --update

使用 vue-element-plus-admin 框架遇到的问题记录

项目打包遇到的问题: 打包语句:pnpm run build:pro 报错信息: Error: [vite]: Rollup failed to resolve import "E:/workplace_gitee/xxx/node_modules/.pnpm/element-plus2.5.5_vue3.4.15/node_modules/element-plus/es/components…

【精品资料】数据安全治理解决方案(27页PPT)

引言:数据安全治理解决方案是一个综合性的体系,旨在通过策略、技术、流程和人力的有机结合,全面提升组织的数据安全防护能力,保障数据资产的安全与合规。 方案介绍:数据安全治理解决方案是组织为确保其数据资产的安全性…

Spark内核的设计原理

导读: 本期是DataFun深入浅出Apache Spark第一期的分享,主讲老师耿嘉安开场介绍了自己的从业经历,当前就职的数新网络与Spark相关的两款产品赛博数智引擎CyberEngine和赛博数据智能平台CyberData。 本次分享题目为《Spark内核的设计原理》&…

智能化一体闸门:助力行业发展

随着科技的飞速发展,智能化技术已经渗透到各个行业和领域,其中水利行业也不例外。智能化一体闸门以其高效、智能、便捷的特点,正助力着行业发展。 一、智能化一体闸门的定义与特点 智能化一体闸门,是集成了先进传感技术、自动控制…

Transformer之Swin-Transformer结构解读

写在最前面之如何只用nn.Linear实现nn.Conv2d的功能 很多人说,Swin-Transformer就是另一种Convolution,但是解释得真就是一坨shit,这里我郑重解释一下,这是为什么? 首先,Convolution是什么? Co…