【JWT】JWT授权认证

欢迎关注微信公众号:全栈工厂

本文主要参考

1. 简介

JSON Web Token(JWT)是一种基于开放标准RFC 7519设计,使用HMACRSA算法签名的无状态授权令牌;由于令牌本身包含了授权所需要的所有信息,因此JWT非常适合分布式的单点服务授权认证。
一个JWT通常由三部分组成:头部(Header)、消息体(Payload)、签名(Signature),大致结构如下图所示:

1.1 头部(Header)

头部一般情况下主要包含两部分信息:

  1. 令牌类型(typ):例如 jwt
  2. 签名算法(alg):令牌签名所使用的算法,例如SHA256RSA等。

所以一个JWT的header值通常为:

   header = base64UrlEncode('{"alg":"SHA256","typ":"JWT"}')
1.2 消息体(Payload)

如果我们认为一个JWT令牌是合法的,那么我们就会从JWT的消息体里面提取令牌的身份信息,这样我们就会知道是谁在使用这个令牌以及令牌是否过期等信息;因此消息体里主要包含令牌的所有实体信息,用户可以自己决定要放那些信息到消息体里面。
所以一个JWT的payload值可以为:

   payload = base64UrlEncode('{ "exp": "1518087620","name": "John Doe","id":"2"}')

表示该令牌的授权人名称是:John Doe,授权人id是:2,令牌过期时间是:1518087620。

1.3 签名(Signature)

签名部分主要用于验证一个JWT令牌的合法性,验证过程非常简单:

  1. 从header中提取出签名所使用的算法(例如SHA256);
  2. 获取服务端在对Token进行签名时所使用的key;
  3. 使用签名算法以及key重新计算签名SHA256(header + "." + payload, key);
  4. 对比新生成的签名和用户提交上来的签名是否一致,完全一致则令牌合法。

2. 总结

2.1 优点

1. 紧凑的设计,方便令牌的存储和传输
JWT的结构设计让它占用的空间更小,可自定义的消息体还可以让令牌存储额外的非敏感信息,简单实用。
2. 无状态的授权认证,方便应用扩展
JWT的无状态特性让服务的横向扩展变得更加简单,服务端不再需要解决类似Session共享等授权信息同步问题。
3. 统一的JSON对象,方便跨平台使用
JWT的header和payload存储的都是JSON对象,因此任何平台的任何语言都可以很方便的进行验证使用。

2.2 缺点

1. 如果令牌泄漏,服务端对令牌的使用失去控制
由于服务端并不存储令牌,如果一个JWT令牌被黑客窃取,除非借助其他技术手段,否则在该令牌有效期内,黑客可以随意使用该令牌,服务端甚至很难发现该令牌已经被窃取。
2. 令牌信息容易暴露,令牌安全完全取决于签名key
JWT令牌的header和payload看起来是一串随机字符串,实际上只是用base64进行编码了而已,用户可以通过使用base64对其解码看到令牌签名所使用的算法以及payload中所存储的授权用户信息;这样黑客就有可能通过header中所标注的签名算法对令牌的签名进行暴利破解,如果签名key被破解出来,那么黑客便可以随意生成自己的JWT令牌,后果不堪设想!因此签名算法中所使用的key极为关键。

注:文中如有任何错误,请各位批评指正!

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 1. 微服务架构介绍 1.1 什么是微服务架构? 形像一点来说,微服务架构就像搭积木,每个微服务都是一个零件,并使...
    静修佛缘阅读 6,635评论 0 39
  • 本文目录:一、单体应用 VS 微服务二、微服务常见安全认证方案三、JWT介绍四、OAuth 2.0 介绍五、思考总...
    挨踢的懒猫阅读 17,955评论 5 29
  • 转载本文需注明出处:微信公众号EAWorld,违者必究。 本文目录: 一、单体应用 VS 微服务 二、微服务常见安...
    72a1f772fe47阅读 8,546评论 3 25
  • 摘要: 在Web应用中,使用JWT替代session并不是个好主意 适合JWT的使用场景 抱歉,当了回标题党。我并...
    ThoughtWorks阅读 276,878评论 157 388