`

八幅漫画理解使用JSON Web Token设计单点登录系统

 
阅读更多

上次在《JSON Web Token - 在Web应用间安全地传递信息》中我提到了JSON Web Token可以用来设计单点登录系统。我尝试用八幅漫画先让大家理解如何设计正常的用户认证系统,然后再延伸到单点登录系统。

如果还没有阅读《JSON Web Token - 在Web应用间安全地传递信息》,我强烈建议你花十分钟阅读它,理解JWT的生成过程和原理。

用户认证八步走

所谓用户认证(Authentication),就是让用户登录,并且在接下来的一段时间内让用户访问网站时可以使用其账户,而不需要再次登录的机制。

小知识:可别把用户认证和用户授权(Authorization)搞混了。用户授权指的是规定并允许用户使用自己的权限,例如发布帖子、管理站点等。

首先,服务器应用(下面简称“应用”)让用户通过Web表单将自己的用户名和密码发送到服务器的接口。这一过程一般是一个HTTP POST请求。建议的方式是通过SSL加密的传输(https协议),从而避免敏感信息被嗅探。

用户登录请求

接下来,应用和数据库核对用户名和密码。

核对用户名密码

核对用户名和密码成功后,应用将用户的id(图中的user_id)作为JWT Payload的一个属性,将其与头部分别进行Base64编码拼接后签名,形成一个JWT。这里的JWT就是一个形同lll.zzz.xxx的字符串。

生成JWT

应用将JWT字符串作为该请求Cookie的一部分返回给用户。注意,在这里必须使用HttpOnly属性来防止Cookie被JavaScript读取,从而避免跨站脚本攻击(XSS攻击)

在Cookie中嵌入JWT

在Cookie失效或者被删除前,用户每次访问应用,应用都会接受到含有jwt的Cookie。从而应用就可以将JWT从请求中提取出来。

从Cookie提取JWT

应用通过一系列任务检查JWT的有效性。例如,检查签名是否正确;检查Token是否过期;检查Token的接收方是否是自己(可选)。

jwtauth6.png

应用在确认JWT有效之后,JWT进行Base64解码(可能在上一步中已经完成),然后在Payload中读取用户的id值,也就是user_id属性。这里用户的id为1025。

jwtauth7.png

应用从数据库取到id为1025的用户的信息,加载到内存中,进行ORM之类的一系列底层逻辑初始化。

jwtauth8.png

应用根据用户请求进行响应。

jwtauth9.png

和Session方式存储id的差异

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

而JWT方式将用户状态分散到了客户端中,可以明显减轻服务端的内存压力。除了用户id之外,还可以存储其他的和用户相关的信息,例如该用户是否是管理员、用户所在的分桶(见[《你所应该知道的A/B测试基础》一文](/2015/08/27/introduction-to-ab-testing/)等。

虽说JWT方式让服务器有一些计算压力(例如加密、编码和解码),但是这些压力相比磁盘I/O而言或许是半斤八两。具体是否采用,需要在不同场景下用数据说话。

单点登录

Session方式来存储用户id,一开始用户的Session只会存储在一台服务器上。对于有多个子域名的站点,每个子域名至少会对应一台不同的服务器,例如:

  • www.taobao.com
  • nv.taobao.com
  • nz.taobao.com
  • login.taobao.com

所以如果要实现在login.taobao.com登录后,在其他的子域名下依然可以取到Session,这要求我们在多台服务器上同步Session。

使用JWT的方式则没有这个问题的存在,因为用户的状态已经被传送到了客户端。因此,我们只需要将含有JWT的Cookie的domain设置为顶级域名即可,例如

1
Set-Cookie: jwt=lll.zzz.xxx; HttpOnly; max-age=980000; domain=.taobao.com

注意domain必须设置为一个点加顶级域名,即.taobao.com。这样,taobao.com和*.taobao.com就都可以接受到这个Cookie,并获取JWT了。

对于JWT的两篇文章有相关问题的同学请直接在下面的评论区与我讨论(请勿邮件讨论)。如果你感兴趣,你可以在下方订阅我的半月刊,我将给你推送更多精彩的内容;)

分享到:
评论

相关推荐

    单点登录中的JSON WEB TOKEN的使用方法C#版

    Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种...该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。本实例还原了整个的使用流程。建议使用vs2019,framework4.8版本。

    基于Java Web Token的单点登录技术研究与实现.pdf

    本文对比以往的单点登录模型,通过Java Web Token(JWT)实现简便单点登录系统。 单点登录技术的分类包括经纪人模型、Kerberos模型、网关模型等。其中,基于经纪人的单点登录认证服务器会集成以往应用服务器的认证...

    第三方单点登录Ecology方案

    总结,"第三方单点登录Ecology方案"是构建一个高效、安全的多应用登录生态的关键步骤,它涉及到身份验证协议、安全性设计、系统集成等多个IT领域的知识。通过这个方案,企业可以提供更加便捷、统一的登录体验,同时...

    单点登录系统的设计与实现

    ### 单点登录系统的设计与实现 #### 一、引言 随着信息技术的发展,用户在不同的应用系统之间频繁切换已成为常态。为了提升用户体验并确保数据安全,单点登录(Single Sign-On, SSO)系统逐渐成为众多企业的首选...

    .net版本单点登录与权限管理(web api)

    在.NET框架中,单点登录(Single Sign-On, SSO)和权限管理是构建安全、高效Web应用程序的关键组件。Web API作为一个轻量级的HTTP服务框架,常用于构建RESTful API,它同样需要处理身份验证和授权问题。下面将详细...

    JWT-Json Web Token-目前最流行跨域身份验证解决方案

    JWT是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,...

    C#版本单点登录与权限管理(web api)

    在IT行业中,单点登录(Single Sign-On, SSO)是一种身份验证机制,它允许用户在一次登录后访问多个相互关联的应用系统,而无需再次进行身份验证。在本项目"**C#版本单点登录与权限管理(Web API)**"中,我们将深入...

    基于JWT实现SSO单点登录流程图解

    基于JWT实现SSO单点登录流程图解是指使用JSON Web Token(JWT)来实现单点登录(SSO)的机制。在这种机制中,用户只需要登录一次,就可以访问多个应用服务器上的资源,而不需要再次登录。下面是基于JWT实现SSO单点...

    Json web token

    JWT被广泛用于认证和授权场景,如单点登录(SSO)系统。 JWT的核心组成部分包括三段:头部(Header)、载荷(Payload)和签名(Signature)。每个部分都是Base64编码的JSON对象,连接在一起,用`.`分隔。 1. **...

    单点登录系统源码放送

    在本文中,我们将深入探讨基于C#实现的单点登录系统源码,以及如何利用这个案例来理解和构建自己的SSO解决方案。 首先,我们要理解SSO的核心概念:凭证共享。当用户在一个应用系统中成功登录后,该系统会生成一个...

    帆软拦截器单点登录.docx

    在这个场景中,我们将讨论如何使用 Java 拦截器来实现帆软报表系统(FineReport)与HIS系统(或其他系统)的单点登录集成。 1. **Java 拦截器原理** Java 拦截器是基于 Java Servlet API 的 Filter 技术,它可以在...

    springCloud-master_单点登录_springCloud单点登录_SpringCloud系统_springclou

    在"springCloud-master_单点登录_springCloud单点登录_SpringCloud系统_springcloud eureka单点登录"这个项目中,我们将重点探讨如何在SpringCloud环境中实现单点登录(Single Sign-On,简称SSO)。 单点登录是一种...

    单点登录跨域iframe互相通信方案.zip

    单点登录(Single Sign-On,简称SSO)是一种身份验证机制,允许用户在一次登录后访问多个相互关联的应用系统,而无需再次输入凭证。在互联网应用中,这种机制极大地提升了用户体验,同时也简化了企业的身份管理。 ...

    Jtoken SSO单点登录模块

    SSO(Single Sign-On)单点登录是一种身份验证机制,允许用户在一次登录后访问多个相互关联的应用系统,而无需再次进行身份验证。JToken SSO单点登录模块是为了解决这一问题而设计的,它简化了在多个应用之间实现SSO...

    第3方系统单点登录OA(Token方案)

    ### 第三方系统单点登录OA(Token方案) #### 一、引言 随着企业信息化建设的不断深入,多个业务系统并存成为常态。这不仅带来了数据孤岛的问题,还使得用户在不同系统间切换时需要频繁登录,降低了工作效率。因此...

    Spring Boot使用JWT实现单点登录.zip

    该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务...

    java应用系统单点登录

    Java 应用系统中的单点登录(Single Sign-On,简称SSO)是一种用户身份验证机制,允许用户在多个相互关联的应用系统中只需登录一次,即可访问所有系统,无需再次进行身份验证。这种技术大大提升了用户体验,同时减少...

    JWT实现的单点登录系统Demo

    **JWT实现的单点登录系统Demo详解** 单点登录(Single Sign-On,简称SSO)是一种用户在多个应用系统中只需登录一次即可访问所有系统的身份验证机制。在现代Web应用程序中,SSO已经成为提高用户体验、简化管理的重要...

    单点登录与权限管理(web api)__0525.rar

    综上,"单点登录与权限管理(web api)__0525.rar"的资料很可能涵盖了以上所述的多个方面,包括SSO的设计原理、C#的实现代码、示例项目等,对于学习和理解如何在C#环境中实现Web API的SSO和权限管理非常有帮助。...

    单点登录与权限管理(web api)

    单点登录(Single Sign-On,简称SSO)是一种网络身份验证机制,允许用户在一个系统上登录后,无需再次认证即可访问多个相互信任的应用系统。它简化了用户在多个应用程序之间的身份验证过程,提高了用户体验,同时也...

Global site tag (gtag.js) - Google Analytics