Session+Cookie+Token

HTTP协议有个特点 , 那就是无状态或者无记忆 , 无记忆的意思就是当我们多次访问同一个网站时 , 每一次访问都需要和服务器建立连接 , 每发一个请求就连接一次 , 请求和请求之间是没有关系的 . 因此服务器无法识别用户的身份信息 , 就无进行权限管理 . 所以 , 就提供了Session和Cookie机制

1.Session和Cookie

1.1 Session

Session是一种在服务器存储数据的技术 .

当客户端发送请求到服务器端时 , 服务器会查看请求是否携带Cookie , 如果携带Cookie , 那么就会查看是否存在Cookie中的SessionId , 如果存在 , 说明当前客户端和服务器已经建立过连接了 , 所以可以通过SessionId 找到该用户存在服务器端的用户信息 ; 如果没有SessionId , 那么则证明当前用户未建立连接 , 此时服务器端就会为当前用户创建一个Session , 并将SessionId 通过 Set-Cookie头发送给客户端 .

1.2 Cookie

Cookie是一种在客户端浏览器存储数据的技术 .

当客户端第一次向服务器端发送请求时 , 服务器端会为该用户生成一个Session 并将用户信息存储在Session中 , 然后将SessionId 发送给客户端 , 客户端收到Cookie后就会将Cookie存储在浏览器上 . 后续对客户端进行访问时 , 就会携带Cookie , 方便服务器判断用户的登录状态和身份信息等 .

1.3 使用Session和Cookie具体步骤

  1. 客户端发送请求
  2. 服务器响应并设置响应头Set-Cookie , 将SessionId发送给客户端
  3. 客户端发送其他请求携带Cookie
  4. 通过Cookie找到用户信息 , 验证用户已经登录

1.4 具体应用 – 用户登录判断

对于一些需要登录才能执行的操作 , 如 : 充值 , 消费等 . 如果用户没有登录就直接进行充值 , 那么服务端就无法判断充值的用户的身份信息 , 充值的金额也无法到达用户账户 . 对于这些操作 , 就可以使用Session和Cookie进行登录判断和用户身份信息获取 .

当用户登录时 , 服务器会根据用户提供的账号和密码找到用户的身份信息 , 并为用户创建一个Session , 然后将用户的身份信息存储在Session中 , 之后将SessionId 通过Set-Cookie头发送给客户端 .
用户登录成功后 , 会将Cookie存在浏览器当中 , 之后在进行充值等操作时 , 会在请求中携带Cookie , 那么服务器就可以通过Cookie中的SessionId找到用户 , 然后对用户的账号余额成功增加了

2 Token – 令牌

由于Session需要在服务器存储用户完整的个人信息 , 所以会占据服务器的存储资源 . 因此又提供了另一种方式识别用户身份信息 – Token ( 令牌 )

Token是一种在客户端和服务器端传递消息的方式 , 当用户成功登录后 , 服务器端会产生一个Token , 返回给客户端 , 客户端在后续请求中 , 将Token携带在请求中 , 发送给服务器 , 服务器验证Token的正确性 , 从而验证用户的身份信息

在这里插入图片描述

2.1 Token的组成 : 标头 + 有效载荷 + 签名

标头 : Token的类型 和 使用的算法
有效载荷 : 用户的部分个人信息
签名 : 通过标头和有效载荷以及密钥加密而成

因此 , 如果Token被修改了前两部分 , 那么就会和签名不一致 , 如果修改了签名 , 就会和前两部分以及密钥加密后的数据不一致 , 因此 , 使用Token可以有效的提高安全性

3. Session , Cookie和Token的对比

在这里插入图片描述

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-27 14:22:04       70 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-27 14:22:04       74 阅读
  3. 在Django里面运行非项目文件

    2024-03-27 14:22:04       62 阅读
  4. Python语言-面向对象

    2024-03-27 14:22:04       72 阅读

热门阅读

  1. 程序员开发技术整理

    2024-03-27 14:22:04       32 阅读
  2. Vue小练习:记录任务所花费时间

    2024-03-27 14:22:04       40 阅读
  3. 分布式事务

    2024-03-27 14:22:04       37 阅读
  4. vue自定义组件实现父子组件数据双向绑定

    2024-03-27 14:22:04       37 阅读
  5. 网络连接中——长连接和短连接详解

    2024-03-27 14:22:04       36 阅读
  6. 物联网(IoT)常用的通信协议

    2024-03-27 14:22:04       36 阅读
  7. deepspeed chat RLHF 个人笔记(待完成)

    2024-03-27 14:22:04       39 阅读
  8. 【Postman】如何给请求的参数设置随机数

    2024-03-27 14:22:04       33 阅读
  9. excel创建和部分使用

    2024-03-27 14:22:04       38 阅读
  10. 数据结构链栈实现(c语言)

    2024-03-27 14:22:04       38 阅读
  11. 软件工程的相关知识点

    2024-03-27 14:22:04       33 阅读