美文网首页笔戈 Web Teamjava收集Java Web
单点登录的三种实现方式

单点登录的三种实现方式

作者: JC_Huang | 来源:发表于2015-09-14 23:20 被阅读98062次

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

  • 存储信任
  • 验证信任

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

以Cookie作为凭证媒介

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

Auth via cookie

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

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

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

通过JSONP实现

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

Auth via jsonp

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

通过页面重定向的方式

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

Auth via redirect

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

使用独立登录系统

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


如果本文对您有用
请不要吝啬你们的Follow与Start
这会大大支持我们继续创作

「Github」
MZMonster :@MZMonster
JC_Huang :@JerryC8080

相关文章

网友评论

  • b8bd7ea7760c:有个问题,第3种方式中,父应用登录成功后,“重定向响应,携带token”,这个token是谁的token?如果是子应用的,父应用如何能够生成子应用可以验证的token???
  • 王_建峰:本质上第二种和第三种没区别呀,理论上有本机能模仿token还是可以破解呀
  • edefb1629f21:独立登录系统这一块怎么样设计比较好。有木有些建议啊
    御浅永夜:这两篇关于SSO思路还是很清晰的https://baike.baidu.com/item/%E5%8D%95%E7%82%B9%E7%99%BB%E5%BD%95/4940767?fr=aladdin
    http://www.cnblogs.com/ywlaker/p/6113927.html
  • 达雅在这里:感谢分享,学习了。
  • Remantou:好文章
  • 北京小六:言简意赅
  • 863c73f31933:问一下作者,点单登录跟免登录一样么?
  • 小步喔:您好,我想问一下,如果是使用前两种方式的话,是不是用户可以做到不需要注册新账户登录,可以记住他使用的ID就可以了呢?
    小步喔: @JC_Huang 谢!
    JC_Huang:@小步喔 单点登录就是要实现一处登录,处处可用的体验。注册的话,理论上一次就可以了。
  • SteveGuRen:第二种方法,JSONP的那一种;如果父应用指的是授权服务器,返回给子应用的是一个授权凭证,子应用验证授权,感觉跟加密算法的关系不大。因为这个凭证是从后台发到前端的,而且访问子应用的所以接口都会带上该授权令牌,因此不可能说伪造,所以这一点我不同意。只要攻击者无法获得正确的授权凭证,那样就没办法去登录子应用了(子应用登录是需要验证令牌的)。
  • fbe6b53cc4a3:你好,請問 JWT 算是独立登录系统的一種嗎?
  • Peter潘的博客:请教一下,如果使用JSONP,“授权应用访问父应用提供的JSONP接口,并在请求中带上父应用域名下的Cookie”。这依然得让子应用和父应用的是同一个域的,其实也没有解决跨域问题吧?
    sdjkfjksdj:@zhuxy 大防守打法阿斯蒂芬
    sdjkfjksdj:@zhuxy 撒的发斯蒂芬第三方
    前端黑板报:@码农一枚 和我的理解一样,并没有解决 a.com b.com单点登录的情况。http://www.onmpw.com/tm/xwzj/network_145.html 这篇文章写的不错。
  • 89cfd286651e:学习了

本文标题:单点登录的三种实现方式

本文链接:https://www.haomeiwen.com/subject/rmcmcttx.html