sso单点登录

https://zhuanlan.zhihu.com/p/153509344
https://developer.aliyun.com/article/636281

普通登录认证机制

image.png
  • 完成登录后,session标记登录状态为yes状态,即已完成登录
  • 浏览器端写入cookie,作为唯一标识
  • 下一次在请求时,会使用cookie找到服务器中对应的session,判断是否登录状态

sso简介

sso:在多个应用系统中,只需要登录一次,就可以访问其他相互信任的应用系统


image.png

其实sso分为同域和不同域下的单点登录,其中同域的简单介绍如下,详细介绍不同域下的,那才是真正的sso单点登录

同域单点登录

我们在设置Cookie时,只能设置顶域和自己的域,不能设置其他的域

一个企业一般情况下只有一个域名,通过二级域名区分不同的系统。比如我们有个域名叫做:a.com,同时有两个业务系统分别为:app1.a.com和app2.a.com。我们要做单点登录(SSO),需要一个登录系统,叫做:sso.a.com。


image.png

如图所示,只要我们在sso.a.com进行登录,就让app1.a.com和app2.a.com进行登录了,需要解决两个问题

  • Cookie是不能跨域的,cookie的domain属性是sso.a.com,则在给app1.a.com和app2.a.com发送请求是带不上的
    解决:sso登录后,将cookie的域设置为顶级域,即.a.com,这样所有子域都可以访问顶域的cookie
  • sso.a.com、app1.a.com和app2.a.com是不同应用,session不共享
    解决:共享session的方案有很多,例如:Spring-Session

不同域单点登录

cookie不共享了


首次访问登录.png

访问a.com下的页面.png

访问b.com下的页面.png
  1. 用户访问网站 a.com 下的 pageA 页面。
  2. 由于没有登录,则会重定向到认证中心,并带上回调地址 www.sso.com?return_uri=a.com/pageA,以便登录后直接进入对应页面。
  3. 用户在认证中心输入账号密码,提交登录。
  4. 认证中心验证账号密码有效,然后重定向 a.com?ticket=123 带上授权码 ticket,并将认证中心 sso.com 的登录态写入 Cookie
  5. 在 a.com 服务器中,拿着 ticket 向认证中心确认,授权码 ticket 真实有效
  6. 验证成功后,将登录状态写入session,并设置a.com域下的Cookie(此时客户端有 2 个 Cookie 分别存有 a.com 和 sso.com 的登录态,一般这个cookie和sso系统传回来的是一样的,然后使用整个cookie的信息,如果不一样就两个cookie合并成一个一起使用了)。

  1. 用户访问b.com系统,b.com系统没有登录,跳转到SSO。
  2. 由于SSO已经登录了,不需要重新登录认证
  3. sso生成ticket,浏览器跳转到b.com系统,并将ticket作为参数传递给b.com
  4. b.com拿到ticket,后台访问sso,验证ticket是否有效。
  5. 验证成功后,b.com将登录状态写入session,并在b.com域下写入Cookie

sso单点登录退出

在同一套认证中心的管理下,多个产品可以共享登录态。现在我们需要考虑退出了,即:在一个产品中退出了登录,怎么让其他的产品也都退出登录?

第5步,每一个产品在向认证中心验证 ticket 时,其实可以顺带将自己的退出登录 api 发送到认证中心。后续直接调用退出api

当某个产品 c.com 退出登录时:

  1. 清空 c.com 中的登录态 Cookie
  2. 请求认证中心 sso.com 中的退出 api
  3. 认证中心遍历下发过 ticket 的所有产品,并调用对应的退出 api,完成退出
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 197,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,846评论 2 374
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 144,146评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,789评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,656评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,467评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,870评论 3 389
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,500评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,790评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,828评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,628评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,449评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,881评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,077评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,376评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,879评论 2 343
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,089评论 2 338

推荐阅读更多精彩内容