jwt token 附加用户信息_JWT(json-web-token) 详解及应用

JWT是一种基于JSON的标准,用于在分布式系统中传递认证信息,常用于SSO场景。相比于传统session认证,JWT更加紧凑、安全,适合扩展。流程包括用户登录获取token,之后携带token进行请求,服务器验证token。JWT由header、payload和signature三部分组成,可存储非敏感信息,且无需服务器保存会话信息,方便扩展。但要注意不在payload存储敏感信息,并保护好私钥。
摘要由CSDN通过智能技术生成

JWT(json-web-token) 详解及应用

什么是JWT

Json web token(JWT)是为了网络应用环境间传递声明而执行的一种基于JSON的开发标准(RFC 7519),

该token被设计为紧凑且安全的,特别适用于分布式站点的单点登陆(SSO)场景。JWT的声明一般被用来在

身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加

一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。

一般用于用户认证(前后端分离/微信小程序/app开发).

基于token的认证和传统的Session认证的区别

# 传统的session认证

http协议本身是一种无状态的协议,而这就意味着如果用户向我们的应用提供了用户名和密码来进行用户认证,

那么下一次请求时,用户还要再一次进行用户认证才行,因为根据http协议,我们并不能知道是哪个用户发送的请求,

所以为了让我们的应用能识别是哪个用户发出的,我们只能在服务器存储一份用户登陆的信息,

这份登陆信息会在响应时传递给服务器,告诉其保存为cookie,以便下次请求时发送给我们的应用,

这样我们的英哟个就能识别请求来自哪个用户了,这就是传统的基于sessino认证,但是这种基于session

的认证使应用本身很难得扩展,随着不用客户端的增加,独立的服务器已无法承载更多的用户,

而这个时候基于session认证应用的问题就会暴露出来.

session:每个用户经过我们的应用认证之后,我们的应用都要在服务端做一次记录,以便用户下次请求的鉴别,

通常而言session都是保存在内存中,而随着认证用户的增多,服务端的开销会明显增大.扩展性:用户认证之后,

服务端做认证记录,如果认证的记录被保存在内存的话,这意味着用户下次请求还必须要请求在这台服务器上,

这样才能拿到授权的资源,这样在分布式的应用上,响应的限制了负载均衡器的能力,也意味着限制了应用的扩展性

CSRF:因为是基于cookie来进行用户识别的,cookie如果被截获,用户就会很容易受到跨站请求伪造的攻击.

# 基于token的鉴权机制

基于token的鉴权机制类似于http协议也是无状态的,它不需要在服务端去保留用户的认证信息或会话信

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值