JWT简介

Json Web Token(JWT)是一种比较流行的用于解决跨域身份验证的解决方案。

在服务器完成身份验证以后,会发送给客户端一个Json对象。在客户端再次和服务器端通信时,会将这个Json对象传给服务器,服务器依据Json对象进行身份验证。

为了防止信息泄漏和被篡改,这个Json对象是要做加密和签名的。

一个JWT,主要包含三个部分,用.分隔。

一、JWT头

元数据区,通常包含如下内容。

{

"alg": "HS256",

"typ": "JWT"

}

alg:表示签名使用的算法,默认为HMAC SHA256(写为HS256);typ属性表示令牌的类型,JWT令牌统一写为JWT。

二、有效载荷

有效载荷部分,是JWT的主体内容部分,也是一个JSON对象,包含需要传递的数据。 JWT指定七个默认字段供选择。

iss:发行人,exp:到期时间,sub:主题,aud:用户,nbf:在此之前不可用,iat:发布时间,jti:JWT ID用于标识该JWT

除以上默认字段外,我们还可以自定义私有字段,如下例:

{

"sub": "1234567890",

"name": "chongchong",

"admin": true

}

三、签名哈希

签名哈希部分是对上面两部分数据签名,通过指定的算法生成哈希,以确保数据不会被篡改。

首先,需要指定一个密码(secret)。该密码仅仅为保存在服务器中,并且不能向用户公开。然后,使用标头中指定的签名算法(默认情况下为HMAC SHA256)根据以下公式生成签名。

HMACSHA256(base64UrlEncode(header) + "." + base64UrlEncode(payload),

secret)

在计算出签名哈希后,JWT头,有效载荷和签名哈希的三个部分组合成一个字符串,每个部分用"."分隔,就构成整个JWT对象。

再说一下BASE64URL 和 BASE64加密算法的不同。

在url中,/ + = 这三个符号有着特殊的含义。而BASE64URL 则对这三个符号进行了替换,/ 用 _ 替代,+ 用-替代,= 直接去掉。

在客户端与服务器的后续交互中都会带JWT,一般放在HTTP header里的Authorization属性中,value 为 Bearer+ 空格 + token。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值