• Token

    • 什么是token
    • 为什么要用token
    • 与传统的SESSION有什么区别
    • token身份验证流程
    • 服务端中跟Token有关的问题
  • JWTJson Web Token
    • 官网地址httpsjwtio
    • jwt githubhttpsgithubcomjwtkjjwt
    • 什么是JWTJson Web Token
    • JWT长什么样子
    • JWT的结构
    • JWT签发与验证流程
    • 注意

Token

什么是token

Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌,服务端根据令牌获取客户端的身份信息。
举个栗子:

http://www.example.com/demo?token=15qwc87wq336scwWFSC2sc1w

为什么要用token

互联网时代信息安全验证放在首要的地位,对于敏感的信息(如账号密码等等)明文的出现次数越少越好。

我们都知道,HTTP协议是一种无状态的协议,这就意味着当我们向应用服务端提供了用户名和密码进行用户认真后,下次请求还是要再进行用户认证,而且服务端又不知道发起请求是谁。按照这个思维,假如每个请求都带有敏感信息,即使进行加密,但是这就增加暴露频率,并且服务端频繁对每个请求的身份信息进行数据查询验证,这是个很大的开销,显然不是我们想要的结果。

为了我们登录后让服务端“记住”我,下次发出请求服务端识别哪个用户发送的,token令牌能解决http无状态的问题,这时候你会觉得SESSION不也一样吗?别急,下面会说到。token就像我们的身份证,客户端一旦得到服务端响应的token后本地缓存,之后每次请求带上token就行了,重要的是开发者可以在token上自定义信息(如UUID),并且是加密的,服务端就减少数据查询验证身份的开销了。

与传统的SESSION有什么区别

如果您还不了解session,请先自行百度学习,这里我简单介绍下:

session 是一种HTTP存储机制,目的是为无状态的HTTP提供的持久机制。

  • Session一般只提供一种简单的认证ID,即JSESSIONID,用户数据只保存在服务端上,因此JSESSIONID尤为重要需要严格保密,这导致了session的弊端:如果web服务器做了负载均衡,那么下一个操作请求到了另一台服务器的时候session会丢失。
  • Session:用户数据保存在服务端;Token:客户端的 cookie 或本地介质存储。
  • Session 更加适合在浏览器上应用,对于开发API接口 Token 是不错的选择。
  • 一旦服务器挂了 sessionid 在服务端内存中映射信息丢失了, token 具有自带性,状态还存在。
  • Token 安全性好,有签名能防止信息篡改、监听、重放攻击。
  • Token 能进行授权操作,Session 不可以。
  • Token 不再依赖于 Cookie,所以你就不需要考虑对 CSRF(跨站请求伪造)的防范。
  • HMACSHA256 计算的 Token 验证和解析的费时比数据库查询 Session 多。

token身份验证流程

  • 客户端使用用户名和密码请求登录验证
  • 服务端接受请求,进行身份验证
  • 验证成功后,服务端会签发一个 Token,再把这个 Token 发送给客户端
  • 客户端收到 Token 后把它存起来
  • 客户端每次向服务端请求时候就带上 Token
  • 服务端收到 Token 后,去验证 Token ,如果验证通过,执行业务逻辑

服务端中跟Token有关的问题

  • 或许你们会想到,Token具有自带性,用户的在线状态不可能存在Token中,那怎么知道用户是否在线呢 ?
    其实服务端中每个Token可以与UUID形成映射对存储在服务器上面,当用户注销操作时,删除UUID与Token的键值对,所以查询不到表示下线了
  • 如何存查删 Token ?
    我们可以把Token信息缓存在内存中,比存在数据库中的好处是读取速度快,开销小,坏处是一旦断点数据全没了,不过token重新认证操作获取就有一个了。基于缓存内存中,memcached、redis,KV方式很适合对token查询的需求。

JWT(Json Web Token)

官网地址:https://jwt.io/

jwt github:https://github.com/jwtk/jjwt

什么是JWT(Json Web Token)

Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。也就是说JWT是Token的一种表述性声明规范。

如果你不清楚JSON请自行学习

JWT长什么样子

eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI3OHNhd2RmZjUiLCJzdWIiOiJ4aWFvdGlhbnRpYW4iLCJpYXQiOjE0OTgwMzE0NDIsImlzcyI6IjEyMi4xMTQuMjE0LjE0NyIsImV4cCI6MTQ5ODAzMjY0Mn0.0h_kDhyZLhnt8TRgbLsOnVT8eOUAqgFTEZP-XgIGuA

上面字符串都是用Base64编码后,发现结构类似:xxx.yyy.zzz

JWT的结构

JWT包含了三个部分,分别用.分割开来,分别是:

  • Header 头部
  • Payload 负载
  • Signature 签名
// 1.Header,包含JWT基础声明,加密算法与类别
{"alg": "HS256", // 加密算法"typ": "JWT"    // 类别
}
// 2.Payload,存放有效信息的地方
// 包含 Claim ,它可以一些实体(通常指的用户)的状态和额外的元数据,有三种类型
// 2.1.Reserved claims JWT标准里面定好的claim,内容如下:
// 2.2.Public claims
// 2.3.Private claims
// 建议的 Claims 不是强制使用的,完全可以按照自己的需求自定义playload,如果是自定义的claims名,您使用的实现库是不会主动去验证它们的
{"aud": "uuu",   // 接受者"iss": "xxx",   // 签发者"exp": "1498499261660", // 过期时间"sub": "yyy",   // 主题"iat": "1498459261660", // 签发时间"jti": "",  // JWT的唯一身份标示"nbf": "1498459261660", // 定义在什么时间之前,该jwt都是不可用的...
}
// 3.Signature,签名,根据Header定义的算法和私钥组合加密
HMACSHA256(base64UrlEncode(header) + "." +base64UrlEncode(payload),secret)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

JWT签发与验证流程

  1. 服务端根据业务需求声明 Header 和 Playload
  2. 将 Header 和 Playload 分别生成 Json 字符串
  3. Header 和 Playload 分别进行base64编码,用 . 分隔开来,组成 JWT 的第一和第二部分,例如:
    eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI3OHNhd2RmZjUiLCJzdWIiOiJ4aWFvdGlhbnRpYW4iLCJpYXQiOjE0OTgwMzE0NDIsImlzcyI6IjEyMi4xMTQuMjE0LjE0NyIsImV4cCI6MTQ5ODAzMjY0Mn0
  4. 得到第3步生成的字符串,根据 Header 里面 alg 指定的签名算法生成出来形成 JWT 的 Signature 部分。算法不同,签名结果不同,常用的值以及对应的算法如下:
  5. 第4步生成的 Signature 组成 JWT 的第3部分,用 . 分隔组成完整的 JWT:
    eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI3OHNhd2RmZjUiLCJzdWIiOiJ4aWFvdGlhbnRpYW4iLCJpYXQiOjE0OTgwMzE0NDIsImlzcyI6IjEyMi4xMTQuMjE0LjE0NyIsImV4cCI6MTQ5ODAzMjY0Mn0.0h_kDhyZLhnt8TRgbLsOnVT8eOUAqgFTEZP-XgIGuA
  6. 到这里服务端签发流程结束
  7. 客户端得到 JWT 后存起来,每次请求带上 JWT 字符串
  8. 服务端收到请求携带的 JWT ,开始进入验证流程
  9. 对 JWT 的完整性进行验证,使用 base64 对 Header 进行解码,知道 JWT 使用什么签名
  10. 重复第4步对 Header 和 Playload 再做一次签名
  11. 比较这个签名是否与 JWT 本身携带的签名完全相同,只要不同,就可以认为该 JWT 是被篡改过的,验证失败,验证流程结束
  12. 如果相同,使用 base64 对 Playload 进行解码,再进行业务逻辑处理,此时验证成功,验证结束。

注意

  • Playload 不要存放敏感信息,因为该部分用base64编码,在客户端是可解的;
  • 服务端保护好secre私钥,一旦客户端得带私匙就可以自己签发 JWT 了;
  • 在网络层面上 token 明文传输的话会非常的危险,所以建议一定要使用 HTTPS ,并且把 token 放在 post body 里。PS:正在准备下一篇关于 HTTPS 的笔记。

from:http://m.blog.csdn.net/wangcantian/article/details/74199762

Web安全通讯之Token与JWT相关推荐

  1. 一文了解web无状态会话token技术JWT

    点击蓝色"程序猿DD"关注我 回复"资源"获取独家整理的学习资料! 来源:码农小胖哥 关注我,回复口令获取可获取独家整理的学习资料: - 001:领取<S ...

  2. 和jwt应用场景_一文了解web无状态会话token技术JWT

    前言 目前web开发前后端已经算非常的普及了.前后端分离要求我们对用户会话状态要进行一个无状态处理.我们都知道通常管理用户会话是session.用户每次从服务器认证成功后,服务器会发送一个sessio ...

  3. Web安全通讯之JWT的Java实现

    上篇文章中目的是介绍 Json Web Token(以下简称 jwt) ,由于我对 Java 比较熟悉就介绍 Java 服务端 的实现方式,其他语言原理是相同的哈~ PS:如果不清楚JWT,请先看 & ...

  4. JSON WEB TOKEN(JWT)的分析

    JSON WEB TOKEN(JWT)的分析 一般情况下,客户的会话数据会存在文件中,或者引入redis来存储,实现session的管理,但是这样操作会存在一些问题,使用文件来存储的时候,在多台机器上 ...

  5. JWT—JSON Web Token - 理解JWT网络间应用用户安全认证交互设计

    原文地址:http://blog.leapoahead.com/2015/09/06/understanding-jwt/ 官网地址:https://jwt.io/ JSON Web Token(JW ...

  6. 单点登录SSO----JSON Web Token(JWT)机制

    JSON Web Token(JWT)机制 pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns: ...

  7. Json Web Token(JWT)

    JsonWebToken 概述 如果各位不了解 JWT,不要紧张,它并不可怕. JSON Web Token(JWT)是一个非常轻巧的规范.这个规范允许我们使用JWT在用户和服务器之间传递安全可靠的信 ...

  8. 后端架构token授权认证机制:spring security JSON Web Token(JWT)简例

    后端架构token授权认证机制:spring security JSON Web Token(JWT)简例 在基于token的客户端-服务器端认证授权以前,前端到服务器端的认证-授权通常是基于sess ...

  9. 还分不清 Cookie、Session、Token、JWT?

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 转自:掘金   作者:秋天不落叶 juejin.im/po ...

  10. 面试官:要不讲讲 Cookie、Session、Token、JWT之间的区别?

    击上方"朱小厮的博客",选择"设为星标" 后台回复"加群",加入组织 来源:22j.co/btPm 什么是认证(Authentication ...

最新文章

  1. 简约而不简单的Django新手图文教程
  2. android 4.3 操作源码实现系统截屏(暂无移植性)
  3. 文本文件的读写(字符流)
  4. 有关像素动作游戏《Resolutiion》美术哲学的讨论
  5. JavaWeb结合七牛云存储搭建个人相册服务
  6. 《剑指offer》按之字行顺序打印二叉树
  7. linux C(hello world)最大公约数和最小公倍数
  8. 怎么删除用户_误删的手机照片怎么恢复?三种快速恢复的方法
  9. erstudio怎么导入mysql数据库?_使用ERStudio生成数据库设计文档。
  10. AtCoder - ABC 168 - E(数学推理)
  11. 2021年兴义五中高考成绩查询,贵州省黔西南州兴义市第五中学2021年招生计划
  12. Matlab-VISSIM联合仿真
  13. 糖尿病合并高血压高龄奥密克戎感染重症、危重症患者诊疗建议 v0(手稿)
  14. 选择框,单选框,组合框,列表框
  15. 1_ARM Cortex-M处理器简介
  16. 使用C/C++来打开与关闭文件(fopenfclose)
  17. 在线预览Word、PDF、图片(IE、Edge、Google、FireFox等主流浏览器)
  18. UDP 端口扫描 - Nmap
  19. 初学Python到月入过万最快的兼职途径(纯干货)
  20. jvm系列_李孟_新浪博客

热门文章

  1. 霍夫线变换,霍夫圆变换
  2. mongodb日志分析工具mtools之mplotqueries
  3. MySQL 5.6 关于登陆的初始化设置
  4. c#中 字节数组到浮点型转换
  5. mysqld got signal 11处理
  6. 应用程序热补丁(三):完整的设计与实现
  7. linux内核分析与应用 -- 进程与线程(下)
  8. 线程相关函数(1)-pthread_create(), pthread_join(), pthread_exit(), pthread_cancel() 创建取消线程
  9. cgroup学习(七)——cpu子系统
  10. 关于在windows中配置flew,glfw