单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任。单点登录在大型网站里使用得非常频繁,例如像阿里巴巴这样的网站,在网站的背后是成百上千的子系统,用户一次操作或交易可能涉及到几十个子系统的协作,如果每个子系统都需要用户认证,不仅用户会疯掉,各子系统也会为这种重复认证授权的逻辑搞疯掉。实现单点登录说到底就是要解决如何产生和存储那个信任,再就是其他系统如何验证这个信任的有效性,因此要点也就以下两个:

  • 存储信任
  • 验证信任

如果一个系统做到了开头所讲的效果,也就算单点登录,单点登录有不同的实现方式,本文就罗列我开发中所遇见过的实现方式。

以Cookie作为凭证媒介

最简单的单点登录实现方式,是使用cookie作为媒介,存放用户凭证。
用户登录父应用之后,应用返回一个加密的cookie,当用户访问子应用的时候,携带上这个cookie,授权应用解密cookie并进行校验,校验通过则登录当前用户。

不难发现以上方式把信任存储在客户端的Cookie中,这种方式很容易令人质疑:

  • Cookie不安全
  • 不能跨域实现免登

对于第一个问题,通过加密Cookie可以保证安全性,当然这是在源代码不泄露的前提下。如果Cookie的加密算法泄露,攻击者通过伪造Cookie则可以伪造特定用户身份,这是很危险的。
对于第二个问题,更是硬伤。

通过JSONP实现

对于跨域问题,可以使用JSONP实现。
用户在父应用中登录后,跟Session匹配的Cookie会存到客户端中,当用户需要登录子应用的时候,授权应用访问父应用提供的JSONP接口,并在请求中带上父应用域名下的Cookie,父应用接收到请求,验证用户的登录状态,返回加密的信息,子应用通过解析返回来的加密信息来验证用户,如果通过验证则登录用户。

这种方式虽然能解决跨域问题,但是安全性其实跟把信任存储到Cookie是差不多的。如果一旦加密算法泄露了,攻击者可以在本地建立一个实现了登录接口的假冒父应用,通过绑定Host来把子应用发起的请求指向本地的假冒父应用,并作出回应。
因为攻击者完全可以按照加密算法来伪造响应请求,子应用接收到这个响应之后一样可以通过验证,并且登录特定用户。

通过页面重定向的方式

最后一种介绍的方式,是通过父应用和子应用来回重定向中进行通信,实现信息的安全传递。
父应用提供一个GET方式的登录接口,用户通过子应用重定向连接的方式访问这个接口,如果用户还没有登录,则返回一个的登录页面,用户输入账号密码进行登录。如果用户已经登录了,则生成加密的Token,并且重定向到子应用提供的验证Token的接口,通过解密和校验之后,子应用登录当前用户。

这种方式较前面两种方式,接解决了上面两种方法暴露出来的安全性问题和跨域的问题,但是并没有前面两种方式方便。
安全与方便,本来就是一对矛盾。

使用独立登录系统

一般说来,大型应用会把授权的逻辑与用户信息的相关逻辑独立成一个应用,称为用户中心。
用户中心不处理业务逻辑,只是处理用户信息的管理以及授权给第三方应用。第三方应用需要登录的时候,则把用户的登录请求转发给用户中心进行处理,用户处理完毕返回凭证,第三方应用验证凭证,通过后就登录用户。

本文转载自 JC_Huang
原文链接:原文

什么是单点登录,实现单点登录的三种方法相关推荐

  1. 【VUE】vue实现登录滑动拼图验证的两种方法,纯前端组件验证以及前后端同时验证

    vue实现登录滑动拼图验证的两种方法: 第一种是纯前端组件验证,只能区分是人为操作还是机器操作. 第二种是前后端同时验证,这种方法加上后端校验相对会更安全一些.(注:在最底部加上了同时兼容移动端的方法 ...

  2. 让Windows XP自动登录的三种方法

    如果你给你的XP设置了密码,那么每次在进入XP桌面之前,都会出现一个用户登录界面,要求输入密码,这样加大了系统的安全性,也为多人共用一台电脑提供了方便,但如果只有你一个人使用,这样每次要输入密码,的确 ...

  3. 英雄联盟登录后服务器显示乱码,英雄联盟大区ID变成乱码,进游戏就闪退,用这三种方法试试看!...

    "如果文章不是为了读者,那将毫无意义,大家好我是张seng" 最近8.11新版本让很多英雄联盟玩家都很失望,除了被削成渣的ADC还有各种无脑的BUG.比如最近很多玩家都遇到了,在游 ...

  4. 三种方法教你开启/关闭win10系统唤醒睡眠模式时需要登录的教程

    Windows系统的睡眠设置给我们带来了极大的方便,因为使用睡眠设置可以保存我们电脑的当前工作状态,再次唤醒睡眠模式时我们可以接着当前的工作状态继续操作,但默认情况下,系统处于安全考虑,当我们从睡眠模 ...

  5. 爬虫模拟登录人人网的三种方法

    # 登录人人网# 第一种,无验证码,直接post 账号密码 并且保存cookie信息到session 进行登录后的访问 # 第一种,无验证码,直接post 账号密码 并且保存cookie信息到sess ...

  6. vue3 微信扫码登录及获取个人信息实现的三种方法

    一.流程: 微信提供的扫码方式有两种,分别是: 跳转二维码扫描页面 内嵌式二维码 根据文档我们可以知道关于扫码授权的模式整体流程为: 1. 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微 ...

  7. 建站操作——WordPress添加用户注册与登录功能(三种方法)

    部分图片转存失败 完整文章请参考我的博客:https://alvincr.com/2020/05/wordpress-test/ 方法一:使用User Registration 选择外观-安装插件进行 ...

  8. java 登录过滤_Java 过滤器实现(登录) + 拦截器(两种方法)

    以下是实现未登录不能进入页面的实现 使用了thyemeleaf+SpringBoot+过滤器实现的,过滤器的核心代码如下: @Component @WebFilter(filterName= &quo ...

  9. 我不那么喜欢的win11,怎么跳过登录微软账号!!! 三种方法

    法① 跳过联网 千万先不要连网啊!!!!!已经连过的试试其他两种 ① 按 Shift+F10键,打开命令行程序(部分笔记本选按Fn+shift+F10) ② 进命令行输入: oobe\bypassnr ...

最新文章

  1. Nhibernate常见的错误
  2. 关于for循环里边是否可以用return语句
  3. Synchronize死锁
  4. sap-生产订单的成本理解
  5. Shiro相关文章资料
  6. android权限询问,Android:检查是否必须询问运行时权限
  7. javascript :得到上星期的这一天日期
  8. code vs1517 求一次函数解析式(数论 纯数学知识)
  9. WPF中的附加行为简介
  10. Linux passwd系统错误,Linux系统处理”passwd: Authentication token manipulation error”错误...
  11. 眼底图像血管增强与分割--(1)匹配滤波算法原理及实现
  12. 软件 规则引擎_如何设计软件规则引擎
  13. maven依赖包快速下载
  14. Ubuntu下载QQ
  15. 航摄比例尺、成图比例尺、地面分辨率与航摄设计用图比例尺
  16. 2年前我从华为外包辞职,如今干到创业公司倒闭,36岁的我该何去何从?
  17. 辟谣!微信支付宝收款码将不能用于经营性收款?
  18. 计算机自定义桌面,电脑桌面图标自定义摆放,如何自定义桌面图标
  19. 笔记本Win11怎么进入安全模式?
  20. 计算机组成原理实验一---运算器 预习报告

热门文章

  1. 报数游戏1-3循环报数,报到3的人退出,求原来的序号
  2. ipa在线安装搭建_AppCake,手机端签名安装IPA,无需越狱
  3. 台式机装苹果系统_iOS系统如何安装外来App?教你一键设置!苹果手机怎么装第三方软件?...
  4. DC-DC升压变换器 直流隔离 高压稳压输出 电源模块
  5. 计算机用户名怎么改好听,电脑版优酷怎么改昵称
  6. 【IPC通信】key_t键和ftok函数
  7. PHP学习----换行符
  8. 字符数组的定义和初始化
  9. 刚刚下载的Ubuntu界面过小问题解决方案
  10. K8S、kubernetes no resolver defined to resolve could not be resolved (3: Host not found) 问题解决