美文网首页
解释一下什么是前后端分离的核心 JWT

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

作者: 小小小8021 | 来源:发表于2020-06-02 22:32 被阅读0次

    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 标注

    [图片上传失败...(image-8b52c9-1591108370379)]

    相关文章

      网友评论

          本文标题:解释一下什么是前后端分离的核心 JWT

          本文链接:https://www.haomeiwen.com/subject/oohmzhtx.html