一篇文章理解JWT(Json Web Tokens)

JWT(JSON Web Tokens)是一种安全的身份验证机制,用于在客户端和服务器间传输信息。它由头、负载和签名三部分组成,常用于用户认证和信息交换。JWT通过HTTP参数或Header传递,但不解决数据加密问题,仍需配合HTTPS确保安全。在认证流程中,用户登录后获取JWT,客户端使用JWT与API服务器交互,服务器验证JWT的有效性和签名,从而确认用户身份。
摘要由CSDN通过智能技术生成

JWT(JSON Web Tokens)是一项RFC的标准,由RFC 7519定义,用于两个实体之间安全地传输用JSON表示的数据。在传输过程中,JWT表现为一个字符串,可以通过HTTP的参数或者Header传输,由三部分字符串用点号相连,格式如下:

header.payload.signature
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.
eyJ1c2VySWQiOiJiMDhmODZhZi0zNWRhLTQ4ZjItOGZhYi1jZWYzOTA0NjYwYmQiLCJleHAiOjEzNzE3MjA5Mzl9.
azSoRzdIHPLTNL2OsJsoXB1qCeThVYeEba_YYt6ZSTw

在应用程序中,JWT主要由JSON格式的header,payload,签名算法及密钥等内容组成。具体我们将在下文描述。

JWT主要的使用场景有:

  • 认证:用户登录后,后续的交互使用JWT来验证
  • 信息交换:可用于传输用户信息等数据

一个典型的场景如下图所示:
这里写图片描述

①首先用户通过用户名密码向认证服务器发起请求
②认证服务器核实

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值