当前位置: 首页 > news >正文

单点登录的实现方式

单点登录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的接口,通过解密和校验之后,子应用登录当前用户。

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

使用独立登录系统

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


转载于:https://juejin.im/post/5b70fa8df265da27e879b5d7

相关文章:

  • 【JZOF】二维数组中的查找
  • TypeScript基础入门 - 类 - 抽象类
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • Redis分布式锁的正解实现方式
  • goLang学习笔记(一)
  • jar解压删除压缩
  • zlog使用手册
  • Dagger2基础篇(一)
  • CreatorPrimer|从zIndex开始
  • (day6) 319. 灯泡开关
  • python其他模块安装
  • jQuery普通绑定事件和on委托事件对比
  • 微信小程序实例:分享给一个人还是分享到群的判断代码
  • 线程与进程的区别(基础面试题)
  • C#将控件置于最顶层和最底层
  • 【干货分享】SpringCloud微服务架构分布式组件如何共享session对象
  • bearychat的java client
  • CentOS从零开始部署Nodejs项目
  • exports和module.exports
  • extract-text-webpack-plugin用法
  • Hibernate最全面试题
  • Java精华积累:初学者都应该搞懂的问题
  • mockjs让前端开发独立于后端
  • Quartz实现数据同步 | 从0开始构建SpringCloud微服务(3)
  • v-if和v-for连用出现的问题
  • Vue2.0 实现互斥
  • Zepto.js源码学习之二
  • 产品三维模型在线预览
  • 缓存与缓冲
  • 简析gRPC client 连接管理
  • 小程序01:wepy框架整合iview webapp UI
  • AI算硅基生命吗,为什么?
  • ​​​​​​​GitLab 之 GitLab-Runner 安装,配置与问题汇总
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • #laravel 通过手动安装依赖PHPExcel#
  • #预处理和函数的对比以及条件编译
  • ( )的作用是将计算机中的信息传送给用户,计算机应用基础 吉大15春学期《计算机应用基础》在线作业二及答案...
  • (C语言)求出1,2,5三个数不同个数组合为100的组合个数
  • (day 2)JavaScript学习笔记(基础之变量、常量和注释)
  • (zhuan) 一些RL的文献(及笔记)
  • (规划)24届春招和25届暑假实习路线准备规划
  • (强烈推荐)移动端音视频从零到上手(上)
  • (转)真正的中国天气api接口xml,json(求加精) ...
  • .NET Core 和 .NET Framework 中的 MEF2
  • .NET Framework杂记
  • .net 调用php,php 调用.net com组件 --
  • .net最好用的JSON类Newtonsoft.Json获取多级数据SelectToken
  • .set 数据导入matlab,设置变量导入选项 - MATLAB setvaropts - MathWorks 中国
  • @JsonFormat与@DateTimeFormat注解的使用
  • @ResponseBody
  • @基于大模型的旅游路线推荐方案
  • [BZOJ4337][BJOI2015]树的同构(树的最小表示法)
  • [math]判断线段是否相交及夹角
  • [pluginviteimport-analysis] vite 提示jsx语法报错
  • [poj] 3422 Kaka's Matrix Travels || 最小费用最大流