基于 JWT 的单点登录设计

1、JWT 简介

Json web token (JWT),是为了在网络应用环境声明而执行的一种基于 JSON 的开放标准。特别适用于分布式站点的单点登录 (SSO),用于认证用户身份信息。

1.1、起源

JWT 的起源还有从传统的 session 认证说起。

1.1.1、传统 session 认证及其弊病

http 协议本身是无状态的协议,正常的若要识别用户身份信息,就需要每次 http 请求都携带用户账户和密码信息,这显然不合理。传统的 session 认证模式如下:


传统 session 认证

传统的 seesion 认证存在的问题:

1)用户信息存储在内存中,用户规模大之后增加服务器开销;
2)由于登录信息存储在内存中,限制了登录机器,不利于分布式站点。

1.1.2、JWT 认证流程

常规的 JWT 认证流程如下如:


JWT 认证

相比于 session 认证,JWT 省去了服务器存储用户信息的过程。

1.2、JWT 格式

下图是 JWT 的格式与内容 https://jwt.io

JWT 格式

如上图,左边的为一个 JWT 示例,它是由点号拼接三个字符串组合而成。红色的是 header 部分,紫色的是 payload 部分,蓝色的 signature 部分。
JWT 格式是:
xxxx.yyyy.zzzz

1.2.1 header 部分

JWT 的头部包含两部分信息:

1)类型声明,这里是 JWT;
2)声明的加密算法,这里是 HS256。
上图的右边红色部分如下:

{
  "alg": "HS256", 
  "typ": "JWT"
}

通过 base64 加密之后,形成图片中左边的第一段字符串 eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9

1.2.2 payload 部分

JWT 的载荷部分存放有效信息,一般由三部分组成:

1)标准注册声明;
2)公用声明;
3)私有声明。

标准注册声明

iss: jwt签发者
sub: jwt所面向的用户
aud: 接收jwt的一方
exp: jwt的过期时间,这个过期时间必须要大于签发时间
nbf: 定义在什么时间之前,该jwt都是不可用的.
iat: jwt的签发时间
jti: jwt的唯一身份标识,主要用来作为一次性token,从而回避重放攻击

一般常用于校验的有 iatexpnbf 校验 token 是否过期。
公有声明
该出可以存放任何信息,例如个性化校验的身份信息等。
私有声明
由于改部分是通过 base64 进行加密的,可以反解,不建议存储任何隐秘信息。
JWT 的第二部分字符串是通过 base64 算法对 payload 信息进行加密。

1.2.3 signature

JWT 的签名部分,有图片中显示的可以看出该部分是服务器利用头部的加密算法和私钥对头部和载荷部分的信息进行加密。

HMACSHA256(
  base64UrlEncode(header) + "." +
  base64UrlEncode(payload),
  your-secret-key)

通过加密,形成 token 的第三部分字符串。

1.3、JWT 常见校验流程

JWT 校验流程

其中设置 payload 校验规则一般是检查 nbfexp 以及用户自定义的一些字段。

2、单点登录介绍

2.1、基于 cookie 的单点登录

一般服务器在用户登录之后,会将 JWT 字符串作为登录请求的 Cookie 的一部分返回给用户,这样在 Cookie 失效或者被删除之前,用户每次访问引用,应用都会借口到含有 JWT 字符串信息的 Cookie,此时便可以取出 JWT 进行校验。
为了在多个域名下共享登录信息,例如:

abc.mycompany.com;
dfs.mycompany.com;
dfs.mycompany.com;
login.mycompany.com; 

当用户在 login.mycompany.com 登录之后,可以设置如下 Cookie:

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

将 domain 设置为 .mycompany.com,这样所有满足 *.mycompany.com 的域名都可以结构该 Cookie,并获取 JWT。

2.2、多顶级域名下的单点登录

基于 cookie 的单点登录模式有一个弊病在于,其对应的多个站点的顶级域名必须相同。为了解决多顶级域名的站点单点登录,内部开发了一套登录模块,其架构如下:


单点登录系统架构

单点登录的流程如下:


单点登录路程

转载整理自
[1]: 什么是 JWT -- JSON WEB TOKEN
[2]: 八幅漫画理解使用 JSON Web Token 设计单点登录系统

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容