专栏首页mySoul解释一下什么是前后端分离的核心 JWT
原创

解释一下什么是前后端分离的核心 JWT

JWT 详解

JWT是为了在网络应用中,前后端交付中,进行页面传值的一种手段。

该TOKEN 设计紧凑,安全,适用于分布式站点的单点登录。

起源

传统的HTTP协议是无状态的,一个用户,只能保存一份用户信息。

这份登录信息,会在传递的时候,无状态的传递给浏览器,告诉其保存为cookie。以便下次的时候,告诉那个用户。

即传统的给予session的前后端认证。

基于Token的鉴权机制。基于token的鉴权机制,类似于HTTP也是无状态的,不需要服务端保留,用户的信息。意味着token认证机制,不需要考虑在那台机器上登录了。

具体的流程如下

  1. 用户使用用户名密码请求服务器。
  2. 服务器验证,用户信息。
  3. 服务器通过认证,颁发token
  4. 客户端保存token。每次请求附带token。
  5. 服务器端验证token值,并返回数据。

JWT 长什么样子

由三部分组成。

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9.TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ

构成

第一部分我们称它为头部(header),第二部分我们称其为载荷(payload, 类似于飞机上承载的物品),第三部分是签证(signature).

头部

声明类型,这里是jwt

声明加密的算法 通常直接使用 HMAC SHA256

对头部进行加密

{
  'typ': 'JWT',
  'alg': 'HS256'
}

然后进行base64加密

eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9

playload

保存有效信息的地方。

通常包含三个部分

标准中注册的声明

公共的声明

私有的声明

标准中注册的声明

iss: jwt签发者
sub: jwt所面向的用户
aud: 接收jwt的一方
exp: jwt的过期时间,这个过期时间必须要大于签发时间
nbf: 定义在什么时间之前,该jwt都是不可用的.
iat: jwt的签发时间
jti: jwt的唯一身份标识,主要用来作为一次性token,从而回避重放攻击。

公共的声明 :

公共的声明可以添加任何的信息,一般添加用户的相关信息或其他业务需要的必要信息.但不建议添加敏感信息,因为该部分在客户端可解密.

私有的声明 :

私有声明是提供者和消费者所共同定义的声明,一般不建议存放敏感信息,因为base64是对称解密的,意味着该部分信息可以归类为明文信息。

signature

用于验证jwt是否发生了改变。

通过秘钥加密,实现jwt是否发生了更改

// javascript
var encodedString = base64UrlEncode(header) + '.' + base64UrlEncode(payload);

var signature = HMACSHA256(encodedString, 'secret'); // TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ

这样通过加密实现了base64位的加密

  eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9.TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ

应用

Authorization 加上 Bearer 标注

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Spring Security 基于数据库的认证

    [wp_editor_md_c80226e17602863cd62006de14c028b6.jpg]

    mySoul
  • 万字长文,SpringSecurity

    [wp_editor_md_ce446408a534c04c207dbf04846f415a.jpg]

    mySoul
  • Spring Batch之批处理实践

    Spring Batch 是Spring的子项目,基于Spring的批处理的框架,通过其可以构建出批量的批处理框架。

    mySoul
  • jwt 实践应用以及特殊案例思考

    JSON Web Token 是 rfc7519[1] 出的一份标准,使用 JSON 来传递数据,用于判定用户是否登录状态。

    coder_koala
  • JWT( JSON Web Token )的 实践,以及与 Session 对比

    Json Web Token 是 rfc7519 出的一份标准,使用 JSON 来传递数据,用于判定用户是否登录状态。

    芋道源码
  • 第二次RNA-seq实战总结(3)-用DESeq2进行基因表达差异分析

    DESeq2是一个用于分析基因表达差异的R包,具体操作姚在R语言中运行 1.R语言安装DESeq2

    HUBU生信
  • 2017谁不会出局,看salck如何打造自已的商业传奇?

    T客汇官网:tikehui.com 编译 | 徐婧欣 ? 编者按:「在昨天的《2017年必有出局者SaaS迎来洗牌季》中,我们看到了一些因战略失误导致资金链断裂...

    人称T客
  • Laravel Migrate修改表和创建表

    php artisan make:migration create_table_test –table=test_a 修改表 Schema::table(‘te...

    苦咖啡
  • JMS的常用方法

    用户3003813
  • ActiveMQ发布订阅模式

    前面讲的案例都是点对点的消息,即一个生产者发送的一条消息只能被一个消费者消费,然后就移除了。

    用户4919348

扫码关注云+社区

领取腾讯云代金券