JSON Web Token设计单点登录系统

用户认证八步走

所谓用户认证(Authentication),就是让用户登录,并且在接下来的一段时间内让用户访问网站时可以使用其账户,而不需要再次登录的机制。
小知识:可别把用户认证和用户授权(Authorization)搞混了。用户授权指的是规定并允许用户使用自己的权限,例如发布帖子、管理站点等。
首先,服务器应用(下面简称“应用”)让用户通过Web表单将自己的用户名和密码发送到服务器的接口。这一过程一般是一个HTTP POST请求。建议的方式是通过SSL加密的传输(https协议),从而避免敏感信息被嗅探。
在这里插入图片描述
接下来,应用和数据库核对用户名和密码。
在这里插入图片描述
核对用户名和密码成功后,应用将用户的id(图中的user_id)作为JWT Payload的一个属性,将其与头部分别进行Base64编码拼接后签名,形成一个JWT。这里的JWT就是一个形同lll.zzz.xxx的字符串。
在这里插入图片描述
应用将JWT字符串作为该请求Cookie的一部分返回给用户。注意,在这里必须使用HttpOnly属性来防止Cookie被JavaScript读取,从而避免跨站脚本攻击(XSS攻击)。
在这里插入图片描述
在Cookie失效或者被删除前,用户每次访问应用,应用都会接受到含有jwt的Cookie。从而应用就可以将JWT从请求中提取出来。
在这里插入图片描述
应用通过一系列任务检查JWT的有效性。例如,检查签名是否正确;检查Token是否过期;检查Token的接收方是否是自己(可选)。
在这里插入图片描述
应用在确认JWT有效之后,JWT进行Base64解码(可能在上一步中已经完成),然后在Payload中读取用户的id值,也就是user_id属性。这里用户的id为1025。
在这里插入图片描述
应用从数据库取到id为1025的用户的信息,加载到内存中,进行ORM之类的一系列底层逻辑初始化。
在这里插入图片描述
应用根据用户请求进行响应。
在这里插入图片描述

和Session方式存储id的差异

Session方式存储用户id的最大弊病在于要占用大量服务器内存,对于较大型应用而言可能还要保存许多的状态。一般而言,大型应用还需要借助一些KV数据库和一系列缓存机制来实现Session的存储。

而JWT方式将用户状态分散到了客户端中,可以明显减轻服务端的内存压力。除了用户id之外,还可以存储其他的和用户相关的信息,例如该用户是否是管理员、用户所在的分桶等.
虽说JWT方式让服务器有一些计算压力(例如加密、编码和解码),但是这些压力相比磁盘I/O而言或许是半斤八两。具体是否采用,需要在不同场景下用数据说话。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单点登录(Single Sign-On,简称SSO)是一种身份认证机制,允许用户使用一组凭据(如用户名和密码)登录到多个相关应用程序或服务,而不需要在每个应用程序中单独进行身份验证。使用token实现单点登录是一种常见的方式。 下面是一个基本的流程来使用token实现单点登录: 1. 用户访问SSO系统,并提供其凭据进行身份验证。 2. SSO系统验证用户的凭据,并生成一个唯一的令牌(token)。 3. SSO系统将令牌返回给用户。 4. 用户在访问其他相关应用程序时,将令牌作为身份验证凭据发送给应用程序。 5. 相关应用程序接收到令牌后,将其发送给SSO系统进行验证。 6. SSO系统验证令牌的有效性,并确认用户的身份。 7. SSO系统向应用程序返回用户的身份信息,应用程序根据此信息决定是否授权用户访问。 在实现过程中,可以使用一些常见的技术和协议,例如JSON Web Token(JWT)或Security Assertion Markup Language(SAML)。这些技术和协议提供了对令牌生成、验证和传输的标准化解决方案。 需要注意的是,使用token实现单点登录需要确保令牌的安全性,以防止被未经授权的用户使用或篡改。常见的安全措施包括使用加密算法对令牌进行签名和验证,以及使用HTTPS协议进行令牌的传输。 以上是一个简单的介绍,实际的单点登录实现可能涉及更多细节和复杂性,具体的实现方式可以根据具体需求和技术栈进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值