单点登录(SSO)
单点登录
单点登录:Single Sign On,简称SSO。用户只要登录一次,就可以访问所有相关信任应用的资源。企业里面用的会比较多,有很多内网平台,但是只要在一个系统登录就可以。
实现方案
- 单一域名:可以把 cookie 种在根域名下实现单点登录
- 多域名:常用 CAS来解决,新增一个认证中心的服务。CAS(Central Authentication Service)是实现SSO单点登录的框架
CAS实现单点登录的流程:
- 用户访问系统A,判断未登录,则直接跳到认证中心页面
- 在认证中心页面输入账号,密码,生成令牌,重定向到 系统A
- 在系统A拿到令牌到认证中心去认证,认证通过,则建立对话
- 用户访问系统B,发现没有有效会话,则重定向到认证中心
- 认证中心发现有全局会话,新建令牌,重定向到系统B
- 在系统B使用令牌去认证中心验证,验证成功后,建议系统B的局部会话。
具体的可以下面的文章,讲解的很详细
关键点
下面是举例来详细说明CAS实现单点登录的流程:
一、第一次访问系统A
- 用户访问系统A (www.app1.com),跳转认证中心 client(www.sso.com),然后输入用户名,密码登录,然后认证中心 serverSSO 把 cookieSSO 种在认证中心的域名下 (www.sso.com),重定向到系统A,并且带上生成的 ticket 参数 (www.app1.com?ticket =xxx)
- 系统A (www.app1.com?ticket =xxx)请求系统A的后端 serverA ,serverA 去 serverSSO 验证,通过后,将cookieA种在 www.app1.com下
二、第二次访问系统A直接携带 cookieA 去访问后端,验证通过后,即登录成功。
三、第三次访问系统B
- 访问系统B (www.app2.com),跳转到认证中心 client(www.sso.com),这个时候会把认证中心的cookieSSO也携带上,发现用户已登录过,则直接重定向到系统B(www.app2.com),并且带上生成的ticket参数(www.app2.com?ticket =xxx)
- 系统B (www.app2.com?ticket =xxx)请求系统B的后端 serverB,serverB 去 serverSSO 验证,通过后,将cookieB种在www.app2.com下
注意cookie生成时机及种的位置。
- cookieSSO,SSO域名下的cookie
- cookieA,系统A域名下的cookie
- cookieB,系统B域名下的cookie
转载自:https://segmentfault.com/a/1190000041859105