Single Sign-on

  SSO是老生常谈的话题了,但部分同学对SSO可能掌握的也是云里雾里,一知半解。本次手撕公司的SSO原理,试图以一种简单、流畅的形式为你提供有用的SSO原理。

  按照本人一贯行文风格,我们先说什么是SSO,为什么要提出SSO?

SSO: 在多个系统中,只需要登录一次,就可以访问其他相互信任的应用系统,表现的实际场景:

  • 企业部署多个website,形成产品套件或产品矩阵,而账号集中统一管理

  • 用户一次登录,即可畅通不同域名下web服务

今天我们主要讲不同顶域下SSO的实现,引出CAS原理,CAS传送门

手绘原理

用户首次访问website1

① 用户访问website1,website1需要认证, 用户当前没有登录

② website1给浏览器返回302重定向, 浏览器重定向到SSO服务页:www.sso-website.com?service=https://www.website1.com

  context.Response.Redirect(ssoURL, false);  // 临时跳转,建议传参false返回302标准重定向响应

用户并没有登录SSO系统,所以SSO系统会返回登录界面

③ 用户在SSO登录页输入账户/密码

④ 登录成功,SSO会在浏览器写入Cookie for sso[官方叫CASTGC]并产生一个302重定向,浏览器将重定向到原website1地址,并携带与此次SSO认证成功的ticket(ST)

http://www.website1.com?ticket=XXXX-OOOO-XXXX-OOOO

⑤ website1收到以上重定向请求,解析QueryString中的ticket, 向SSO做一次ticket验证;

⑥⑦ 验证通过之后,会写入本站的Cookie for website1, 同时会302重定向要求回到业务首页:www.website1.com。

已认证用户访问website2

① 用户访问website2,用户在website2域并没有认证;跳转回www.sso-website.com?service=https://www.website2.com

② SSO检测到该用户在SSO域下存在Cookie for sso, 认定该用户已经登录,故跳转回www.website2.com?ticket=XXXX-OOOO-XXXX-OOOO, 如上也会携带认证ticket

③ 如上,website2收到 website2.com?ticket=XXXX-OOOO-XXXX-OOOO请求,在做一次SSO验证; 验证成功,写入本站Cookie for website2

重难点解读

① SSO认证成功,写入的cookie for sso, 是登录到其他系统的关键

② website1收到SSO发起的重定向请求,解析出ticket=XXXX-OOOO-XXXX-OOOO, 为什么还要做一次SSO验证?

因为website1收到的带ticket请求,有可能是伪造(复制别人的带ticket地址 www.website1.com?ticket=XXXX-OOOO-XXXX-OOOO,实际没有sso登录), 所以在website1中需要去SSO验证一次(sso会验证这个ticket在sso站点是否已经是登录用户)。

③ 标准的CAS登录流程有三次302浏览器重定向, 分别由原站点website1启动2次和SSO启动一次

理论上流程由服务端重定向也是可以的 ?? 看官若发现有漏洞,可在评论区回复。

20200201 更新,三次跳转均不可使用服务端跳转!!!

第一次website1重定向回 sso.com,第二次SSO重定向回 website1.com不能使用服务端重定向, 服务端重定向相当于A站点请求了B站点的资源,浏览器地址并不会改变, 这样的操作导致此流程并不能产生独立的 Cookie for sso, Cookie for website1, 故不能使用服务端跳转, 应保持302 跳转(这是HTTP协议的行为)。

对于第三次重定向,发生在最后一步:跳转回首页 website1.com,页面其他资源需使用刚写入的Cookie for website1,故此处也不可使用 服务端跳转。

④ 退出SSO登录, 要做两件事情:

- 向SSO发起api请求,请求SSO删除用户在SSO域下的认证cookie for sso

- 移除本站的cookie for website1

⑤ 每个website,至少需要如下sso配置

  "SsoOptions": {
"BaseAddress": "https://sso-cas.sso.com",     // 基地址
"LoginPath": "/login", // sso登录地址
"LogoutPath": "/api/logout", // 退出sso登录的api地址
"ValidateTGTPath": "/api/validate", // 验证ticket的api地址
"UserInfoPath": "/api/v2/userinfo" // 从sso拿到登录用户信息的api地址
},

That' all,这是自己对SSO登录的一些理解, 本图文希望以流畅的思路记录SSO流程, 各位看官不要吃快餐,知其然更知其所以然很关键。

手撕公司SSO登陆原理的更多相关文章

  1. 编译原理--05 用C++手撕PL/0

    前言 目录 01 文法和语言.词法分析复习 02 自顶向下.自底向上的LR分析复习 03 语法制导翻译和中间代码生成复习 04 符号表.运行时存储组织和代码优化复习 05 用C++手撕PL/0 在之前 ...

  2. 手撕spring核心源码,彻底搞懂spring流程

    引子 十几年前,刚工作不久的程序员还能过着很轻松的日子.记得那时候公司里有些开发和测试的女孩子,经常有问题解决不了的,不管什么领域的问题找到我,我都能帮她们解决.但是那时候我没有主动学习技术的意识,只 ...

  3. MVC4/5+jquery+bootstrap样式+dataTables+linq+WCF+EF6后台和前台的框架集合!好蛋疼哦!数据库支持MYSQL 和MSSQL,oracle。集成腾讯企业邮箱收邮件同步用户SSO登陆等功能。

    花费了我好多心血,才做出来,下个项目准备用这个框架! 大家有没有做这方面的可以交流一下! 花费了我好多心血,才做出来,下个项目准备用这个框架! 大家有没有做这方面的可以交流一下! 花费了我好多心血,才 ...

  4. NN入门,手把手教你用Numpy手撕NN(2)

    这是一篇包含较少数学推导的NN入门文章 上篇文章中简单介绍了如何手撕一个NN,但其中仍有可以改进的地方,将在这篇文章中进行完善. 误差反向传播 之前的NN计算梯度是利用数值微分法,虽容易实现,但是计算 ...

  5. 优雅手撕bind函数(面试官常问)

    优雅手撕bind函数 前言: 为什么面试官总爱让实现一个bind函数? 他想从bind中知道些什么? 一个小小的bind里面内有玄机? 今天来刨析一下实现一个bind要懂多少相关知识点,也方便我们将零 ...

  6. 用C/C++手撕CPlus语言的集成开发环境(1)—— 语言规范 + 词法分析器

    序言 之所以叫做CPlus语言,是因为原本是想起名为CMinus的,结果发现GitHub和Gitee上一堆的CMinus的编译器(想必都是开过编译原理课程并且写了个玩具级的语言编译器的大佬们吧).但是 ...

  7. 面试中的MySQL主从复制|手撕MySQL|对线面试官

    关注微信公众号[程序员白泽],进入白泽的知识分享星球 前言 作为<手撕MySQL>系列的第三篇文章,今天讲解使用bin log实现主从复制的功能.主从复制也是MySQL集群实现高可用.数据 ...

  8. java实现二叉树的Node节点定义手撕8种遍历(一遍过)

    java实现二叉树的Node节点定义手撕8种遍历(一遍过) 用java的思想和程序从最基本的怎么将一个int型的数组变成Node树状结构说起,再到递归前序遍历,递归中序遍历,递归后序遍历,非递归前序遍 ...

  9. Palm是一家英國智能手機公司

    據TCL方面介紹,本次收購只涉及品牌,不會涉及員工和其他資產.被收購之後,Palm仍將繼續把總部設於美國加州矽谷,以發揮該區域所獨有的先進技術和人才的優勢. TCL通訊CEO郭愛平表示TCL將把Pal ...

随机推荐

  1. JS 时间格式 相互转化

    1. 时间字符串格式 var dateString1 = '2016-06-15 10:22:00'; var dateString2 = '2016/06/15 10:22:00'; var dat ...

  2. Angular ngx-echarts图表

    1. 安装echarts包.ngx-echarts包 npm install echarts --save npm install ngx-echarts --save 2. angular.json ...

  3. mui中判断是点击还是滑动

    判断和滑动是两种触发方式 滑动分为四种,上下左右(swipeup,swipedown,swipeleft,swiperight) 点击分为两种,点击和双击,一般用单机(tap) 根据自己不同的需求进行 ...

  4. 由std::once_call 引发的单例模式的再次总结,基于C++11

    一个偶然的机会,知道了std::once_call这个东西. 了解了下,std::once_call支持多线程情况下的某函数只执行一次.咦,这个不是恰好符合单例模式的多线程安全的困境吗? 单例模式,经 ...

  5. MongoDB 学习笔记之 检测存储引擎

    检测存储引擎: db.serverStatus().storageEngine db.serverStatus().wiredTiger (转)WiredTiger测试结果 单纯写的测试结果 结论:W ...

  6. PHP生成唯一ID的方法

    PHP自带生成唯一id的函数:uniqid() 它是基于当前时间微秒数的 用法如下: echo uniqid(); //13位的字符串 echo uniqid("php_"); / ...

  7. 设计模式----创建型模式之工厂模式(FactoryPattern)

    工厂模式主要分为三种简单工厂模式.工厂方法模式.抽象工厂模式三种.顾名思义,工厂主要是生产产品,作为顾客或者商家,我们不考虑工厂内部是怎么一个流程,我们要的是最终产品.将该种思路放在我们面向对象开发实 ...

  8. LeetCode_20-Valid Parentheses

    给定一个字符串,其中包含字符’(’,’)’,’[’,’]’,’{‘,’}’,左括号必须匹配右括号,一对匹配的括号不能单独出现单个左括号或者右括号.如:(()[])有效,[(])无效空字符串也算是有效的 ...

  9. Nexus搭建开发组的私有仓库

    一.私有仓库的价值 开发Java应用系统,用到Maven.sbt和 Gradle等构建工具,在构建过程中一般需要从互联网下载依赖库,构建私有仓库就是为了在开发组或者部门内共用,从而节省整体的下载成本和 ...

  10. PhpSpreadsheet 导出特定格式 — 广告请款单

    需求说明 最近需要实现一个导出这种格式的Excel表单,之前都有用过导出Excel的功能,但大都是表头+数据的形式,只用于获取数据,没有太多样式要求,不用合并单元格.合并居中等,也不用对每一行数据特异 ...