单点登录(single sign on),简称sso。它的定义是多个应用系统间,只需要登录一次就可以访问所有相互信任的应用系统。下面介绍用jwt技术如何来实现单点登录。

一、JWT定义及其组成

JWT(JSON WEB TOKEN)是一个非常轻巧的规范,这个规范允许我们使用jwt在客户端和服务器之间传递安全可靠的信息。

JWT由3个部分组成,分别是头部、载荷、签名。

头部部分

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

alg描述的是签名算法。

载荷部分

{
  "iss": "发行者",
  "sub": 主题",
  "aud": “观众”,

"exp":"过期时间",

"iat":"签发时间"

以下可以添加自定义数据

"userid":"11111",

“realname":"真实姓名",

"email":"",
}

Base64算法是可逆的,不可以在载荷部分保存用户密码等敏感信息。如果业务需要,也可以采用对称密钥加密。

签名部分

HMACSHA256(Base64(Header) + "." + Base64(Payload),  secret)

签名的目的是用来验证头部和载荷是否被非法篡改。

验签过程描述:读取Header部分并Base64解码,得到签名算法。根据以上方法算出签名,如果签名信息不一致,说明是非法的。

二、认证过程

下面我们从一个实例来看如何运用JWT机制实现认证:

登录

  • 第一次认证:第一次登录,用户从浏览器输入用户名/密码,提交后到服务器的登录处理的Action层(Login Action);
  • Login Action调用认证服务进行用户名密码认证,如果认证通过,Login Action层调用用户信息服务获取用户信息(包括完整的用户信息及对应权限信息);
  • 返回用户信息后,Login Action从配置文件中获取Token签名生成的秘钥信息,进行Token的生成;
  • 生成Token的过程中可以调用第三方的JWT Lib生成签名后的JWT数据;
  • 完成JWT数据签名后,将其设置到COOKIE对象中,并重定向到首页,完成登录过程;

请求认证

基于Token的认证机制会在每一次请求中都带上完成签名的Token信息,这个Token信息可能在COOKIE
中,也可能在HTTP的Authorization头中;

  • 客户端(APP客户端或浏览器)通过GET或POST请求访问资源(页面或调用API);
  • 认证服务作为一个Middleware HOOK 对请求进行拦截,首先在cookie中查找Token信息,如果没有找到,则在HTTP Authorization Head中查找;
  • 如果找到Token信息,则根据配置文件中的签名加密秘钥,调用JWT Lib对Token信息进行解密和解码;
  • 完成解码并验证签名通过后,对Token中的exp、nbf、aud等信息进行验证;
  • 全部通过后,根据获取的用户的角色权限信息,进行对请求的资源的权限逻辑判断;
  • 如果权限逻辑判断通过则通过Response对象返回;否则则返回HTTP 401;
三、java代码实现
1、用户登录:
用户登录验证通过后添加以下代码
String token = JwtUtil().generateToken(userName);
Cookie cookie = new Cookie("autotoken", token);
response.addCookie(cookie);

2、调用http请求

后续的http请求认证都带上token
3、应用系统认证
编写一个过滤器,对每一个请求进行解码认证
 String authToken = request.getHeader(this.tokenHeader);if (jwtTokenUtil.validateToken(authToken) {
//认证通过
}

使用jwt技术实现系统间的单点登录相关推荐

  1. 在不同域中各个系统拥有自已独立的用户系统时的单点登录问题

    我们在实现业务中经常会碰到多个系统各自有各自的用户登录系统,而且这些系统是各自运行在各自的域下,所以要实现这些系统用户的单点登录就是个问题了,所以自己想了一个方案希望看看是否可行. 1.sso站点必须 ...

  2. trs ids身份服务器系统实现统一身份认证与单点登录平台技术,统一身份认证和单点登录系统建设方案.pdf...

    福建省公安公众服务平台 统一身份认证及单点登录系统建设方案 福建公安公众服务平台建设是我省公安机关 "三大战役"社会管 理创新的重点项目之一: 目前平台目前已经涵盖了公安厅公安门户 ...

  3. VUE+SpringBoot+JWT实现token验证,SSO单点登录

    Session的产生: 在说session是啥之前,我们先来说说为什么会出现session会话,它出现的机理是什么?我们知道,我们用浏览器打开一个网页,用到的是HTTP协议,htpp协议是无状态的,什 ...

  4. 单点登录系统SSO概述 | 单点登录讲解(1)

    本项目主要讲解的是单点登录系统的原理及其实现. 本章主要讲解的是单点登录系统的概述部分. 单点登录 单点登录顾名思义就是从一个系统进行登录操作,就可以访问其他附近的系统.单点登录避免了用户重复的登录过 ...

  5. 挑战用五行代码轻松集成登录系统,实现单点登录

    随着企业业务的发展,OA 系统.财税系统.CRM 系统等各类系统只增不减,权限管理也日渐力不从心.很多企业都在寻找这样一种服务--员工只需登录个人 OA 系统的账号密码,就可以访问飞书.销售易.客户系 ...

  6. windows系统下部署单点登录系统

    windows系统单点登录 1:在 D:\software\java\learning\sso\keys 目录下生成 keystore keytool -genkey -alias mykey -ke ...

  7. 统一用户单点登录系统

    see also:http://www.ibmtech.com.cn/dandian.html 统一用户单点登录的基本原理 一般来说,每个应用系统都拥有独立的用户信息管理功能,用户信息的格式.命名与存 ...

  8. 统一用户认证和单点登录(SSO)解决方案

    本文以某新闻单位多媒体数据库系统为例,提出建立企业用户认证中心,实现基于安全策略的统一用户管理.认证和单点登录,解决用户在同时使用多个应用系统时所遇到的重复登录问题. 随着信息技术和网络技术的迅猛发展 ...

  9. 单点登录总结(域名内与跨域名)

    多系统情况下经常需要进行单点登录,分为: 1.域名内系统间的单点登录 域名内指一级域名一致.由于cookie会共享,所以登录ID存到cookie中,各系统可从cookie中直接取到登录ID. 通过账户 ...

最新文章

  1. Python最会变魔术的魔术方法,我觉得是它
  2. Linux查看文件夹大小的命令
  3. ansible的模块使用
  4. extjs gridpanel滚动条问题显示数据不完整
  5. JS过滤空格,回车符。
  6. matlabapp窗口图像_matlab – 如何自定义App Designer图形的背景?
  7. 计算机指令int,汇编入门学习笔记 (十二)—— int指令、端口
  8. atitit.提升开发效率---mda 软件开发方式的革命
  9. DataGridView使用技巧一:获取或设置当前单元格的内容
  10. php调用文章至首页,WP如何在首页调用分类文章列表的详细教程
  11. Selenium Grid跨浏览器-兼容性测试
  12. 【English】十六、时间相关
  13. java 数据透视表 组件_Apache POI如何将工作簿样式应用于所有数据透视表 . 我如何排除床单?...
  14. 杜比专为旧版本Android,杜比音效7.0清爽卡刷包-杜比音效7.0定制版v2.1.0 安卓版-腾牛安卓网...
  15. PEST、波特五力、波士顿矩阵、SWOT、价值链等战略分析方法整理学习笔记
  16. ListView列表项View复用--ViewHolder模式
  17. PySide6精简教程
  18. Python学习之Turtle库
  19. 使用tkinter打造一个小说下载器,想看什么小说,就下什么
  20. 爬虫进阶 -- 神级程序员:让你的爬虫就像人类的用户行为!

热门文章

  1. 【Unity3D】关于 InputManager 以及改键功能的制作
  2. python软件基金会在哪个国家举行_官宣!Python 开发者大会(PyCon US)提供在线订阅啦!...
  3. maven的setting文件-02
  4. c语言和c 自学,自学C语言最常遇到的七个问题
  5. 90天掌握高级JS(第一个阶段日志)
  6. netty-第一个案例
  7. 第一次机房收费系统总结
  8. 2022年信息安全工程师考试知识点:无线网络安全
  9. Gif裁剪工具如何操作?教你三步快速裁剪gif动图
  10. 传感器自学笔记第十一章——三色RGB学习笔记+高感度声音检测模块+KY-010光遮断传感器+TCRT5000循迹传感器+倾斜模块