单点登录SSO:概述与示例
目录
单点登录SSO概述
本系列将由浅入深的,带大家掌握最新单点登录SSO方案选型,以及架构开发实战。系列将结合示例、源码以及演示视频,让大家能够直观、深入学习。
文末附5个满足不同单点登录场景的gif动画演示。本系列后继文章会深入它们的实现方式以及适用场景,大家也可以先观看揣摩其实现。
零改造实施单点登录 单点注销 集成AD认证 客户端单点登录 移动端单点登录
单点登录即Single Sign On(SSO)。它是大型政府OA、企事业单位OA的标配解决方案。它概言之就是在多个Web、桌面或移动应用系统中,用户只需要登录一次,就可以访问所有的应用系统。
从业十多年,为政府、电信、跨国公司顾问和实施的单点登录解决方案无数,深谙其痛点与关键。
和很多人直观猜测相反,单点登录方案的定制性很强。很多企业的单点登录,实施是有问题的。尤其是被一些软件产品的销售人员牵着走的企业,它的单点登录方案实施,从产品方案选型起就存在根本性问题。这些方案常常要求大量现有业务系统的改造(基于统一身份认证服务,采用OpenId,OAuth,SAML等技术创建和传递认证凭据),或者只是体验较差的类似浏览器自动填充账号密码的功能(如Oracle的ESSO)。它们要么改动面大、周期长,要么服务端和客户端局限性多,用户体验也达不到最佳。
事实上,单点登录的实施环境与需求千差万别:有纯Web的(常见又分跨域不跨域的),有桌面应用的,有移动平台的,有要结合Windows登录凭据的,有整合了标准方案的,有不能改动现存系统的,等等等等。最适合企业的方案,一定需要结合企业应用种类、各系统供应商状况、终端要求、后期扩展性需求、实施成本工期来具体确定。
很多单点登录解决方案的实施,由于顾问的经验、视野或产品倾向性原因,往往导致了这些结果:
1. 明明可以不需要改造被集成系统的,偏偏处处受困于诸多被集成系统的改造。
这个是很多开源免费或者商用的单点登录产品,在实施时最普遍遇到的情况。它们往往基于统一身份认证服务,采用OpenId,OAuth,SAML等技术创建和传递认证凭据,要求各个被集成应用按照相应接口开发。对于不同厂商在不同技术平台、不同维护时间、不同业务场景下构造的多个系统,要求统一按照方案接口标准做改造,其难度可想而知。见过不止一家厂商,他们的业务系统在客户那边已经上线运行,客户后来提出单点登录的集成要求,于是为了快速完工,完全不遵循业界安全规范,采用最简单暴力的方式进行集成,结果导致严重的安全漏洞。
其实,百分之九十以上的业务场景,我们都可以通过不止一种方式,在不改造现有系统的情况下,实现它对单点登录的支持。下文会给出多个示例、github源码,以及演示视频。
2. 明明可以在移动端、桌面端实现跨平台单点登录的,偏偏依赖于特定终端,甚至特定浏览器。
有一家跨国公司,选型某知名软件做单点登录解决方案,它的优点是对被集成系统可以零改造,但只支持Windows终端,因为它有一个Windows程序要安装到每个用户机器上。我作为实施顾问参与时,发现其中绝大部分用户常用的系统都是几个Web系统,完全可以通过实施服务端零改造的SSO方案,避免向他们机器推送一个要按终端数购买授权的应用。这类应用不但授权费用高昂(每终端数千元),而且部署维护成本高、很多设备环境和个性化浏览器下会出兼容性问题。
3. 明明可以和统一身份认证(Identity Authentication)、统一身份管理(Identity Management)分开实施的,偏偏被“忽悠”买了数百万的打包解决方案。
SSO和这两者在应用场景和一些实施方案上有交集,使得很多实施顾问会利用这点,让很多企业不明就里的“明明只想剪个头发,结果买了美容保养年卡,而且头发还剪得不好”。
统一身份认证,往往和多个Web应用基于服务端做SSO的方案绑定销售。对于有多个Web应用要做服务端SSO的,尤其是包含多个跨一级域名应用的,常常被推荐部署独立的统一身份认证服务产品,然后让各个应用针对它的接口做开发集成。让各个Web或桌面、移动应用,集成、识别并认可其认证凭据,还要和该服务器安全交换用户身份信息,是一个不小的挑战。现有各个系统的服务商是否还会及时的配合开发本身已是一个大问题,即使他们配合,在一个环节出现问题就会是严重的安全漏洞。
统一身份管理主要是针对企业账户安全领域。它的主要作用,简而言之就是在一个地方管理所有系统账号的创建和终止,避免一个员工离职要到多个应用管理部门做账号删除,很容易出现漏删账号,导致企业信息安全问题。针对很多大型组织架构来讲,它确实也非常必要,我个人实施顾问的很多企业确实也非常需要,后面我会撰文详述这一块的经验心得。这方面现成产品有诸如Oracle的OIM,IBM的Tivoli IM,都是光买授权就动辄上百万的产品(具体费用和用户数、服务器等相关),它们的特点是针对很多大型应用诸如SAP、Lotus Notes等等都有现成的连接器来做账号资源的推拉(Provision/Reconciliation)。但对于没有现成连接器的产品,需要定制开发,这块对于实施人员要求很高,而且后期的维护、新应用的集成基本都完全依赖第三方,成本高昂。
4. 明明可以精干团队一个月实施完的,偏偏劳师动众多个供应商、多个部门折腾三四个月。
SSO实施和业务系统开发不同,它是技术点密集但工作量少的业务。如果你的开发人员还要为“如何跨域传token”、“如何读写AD”之类现学摸索,那实施结果往往存在较大安全漏洞,也会导致工期不可预测。这一块的很多现成产品都有特定的实施要求和局限性(本人曾填坑Oracle的OIM 和 ESSO),加之实施人员对产品熟悉程度不一,导致企业稍有自身特定的情况,就会要花费大量工时研究调整,甚至最终无法按需交付。
单点登录SSO方案示例
先来几组单点登录方案演示吧,本系列后继文章会深入它们的具体实现方式以及适用场景。
演示一:零改造单点登录CSDN、百度
演示二: 单点注销
演示三:集成AD认证
演示四:客户端单点登录QQ、VPN
演示五:移动端单点登录
原文地址:http://www.cnblogs.com/baibaomen/p/sso.html 。转载须保留本链接。
本系列各篇链接:
单点登录-SSO:概述与示例 http://www.cnblogs.com/baibaomen/p/sso.html
单点登录-SSO:图示和讲解 http://www.cnblogs.com/baibaomen/p/sso-sequence-chart.html
单点登录-SSO:一键运行的完整代码 http://www.cnblogs.com/baibaomen/p/sso-full-code.html
本作品采用知识共享署名-非商业性使用-相同方式共享 2.5 中国大陆许可协议进行许可。
我的博客欢迎复制共享,但在同时,请保留原文地址以及我的署名权百宝门-SSO顾问,并且,不得用于商业用途。
如您有任何疑问或者授权方面的协商,请给我邮件。
博客园专栏:
百宝门-SSO顾问
单点登录SSO:概述与示例的更多相关文章
- 【Spring Boot&& Spring Cloud系列】单点登录SSO概述
概念 单点登录(Singleton Sign On),简称为SSO,是目前比较流行的企业业务整合的解决方案之一.SSO的定义是在多个应用系统中,用户只需要登录一次就能访问所有相互信任的应用系统. 也就 ...
- [转载]单点登录SSO:概述与示例
原文地址: https://www.cnblogs.com/baibaomen/p/sso.html 目录 概述 演示一:零改造实施单点登录 演示二: 单点注销 演示三:集成AD认证 演示四:客户端单 ...
- 单点登录SSO:可一键运行的完整代码
单点登录方案不同于一个普通站点,它的部署比较繁琐:涉及到好几个站点,要改host.安装证书.配置HTTPS. 看到的不少这方面示例都是基于HTTP的,不认同这种简化: 1. 它体现不出混合HTTP/H ...
- 单点登录SSO:图示和讲解
目录 概述 示例运行效果动画 跨域Web SSO时序图 代码截图 几个基本概念 涉及的站点和页面 重点理解:单点登录的核心步骤 敢说最准确的单点登录图示,因为: 我严格对照所画时序图的每个步骤,开发了 ...
- cas单点登录 SSO 的实现原理
原文出处: cutesource 欢迎分享原创到伯乐头条 单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户 ...
- 单点登录 SSO 的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任. 单点登录在大型网站里使用 ...
- Atitit. 单点登录sso 的解决方案 总结
Atitit. 单点登录sso 的解决方案 总结 1. 系统应用场景and SSO模式选型 2 2. 系统应用的原则与要求 2 2.1. 开发快速简单::绝大部分系统来说,开发快速简单为主 2 2. ...
- 十六、【适合中小企业的.Net轻量级开源框架】EnterpriseFrameWork框架核心类库之单点登录SSO
回<[开源]EnterpriseFrameWork框架系列文章索引> EFW框架源代码下载:http://pan.baidu.com/s/1qWJjo3U 单点登录(Single Sign ...
- 单点登录SSO的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...
随机推荐
- (python)面向对象
一.面向对象概述 要了解面向对象,就需要先了解面向过程的概念,那么什么是面向过程编程呢?最具代表性的就是C语言了,所谓面向过程编程就是在做一件事的时候,需要按步骤进行,第一步干什么,第二步干什么,这种 ...
- python 交互式命令行数据库连接助手 -- mysql、sql server (mssql)、redis
目录 python 交互式命令行数据库连接助手 0. 操作示例 1. python 连接mssql 2. python 连接mysql 3. python 连接redis n. Tips python ...
- Linux CFS调度器之pick_next_task_fair选择下一个被调度的进程--Linux进程的管理与调度(二十八)
1. CFS如何选择最合适的进程 每个调度器类sched_class都必须提供一个pick_next_task函数用以在就绪队列中选择一个最优的进程来等待调度, 而我们的CFS调度器类中, 选择下一个 ...
- c++ 右值引用,move关键字
c++ move关键字 move的由来:在 c++11 以前存在一个有趣的现象:T& 指向 lvalue (左传引用), const T& 既可以指向 lvalue 也可以指向 rv ...
- Cs231n课堂内容记录-Lecture1 导论
Lecture 1 视频网址:https://www.bilibili.com/video/av17204303/?p=2 https://zhuanlan.zhihu.com/p/21930884? ...
- python--私有属性--私有方法
Class 定义类 def 初始化方法(形参) 属性1 属性2 私有属性(属性之前加--) def 方法1() print() 属性和方法定义好以后,在创建对象 对象=类名(“”) print( ...
- Linux: yum配置说明
下面是利用 man yum.conf 命令获取到的有关yum配置的说明: yum.conf(5) yum configuration file yum.conf(5) NAME yum.conf - ...
- 【算法】LeetCode算法题-Reverse Integer
这是悦乐书的第143次更新,第145篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第2题(顺位题号是7),给定32位有符号整数,然后将其反转输出.例如: 输入: 123 ...
- February 11th, 2018 Week 7th Sunday
Grasp all, lose all. 欲尽得,必尽失. Not to be greedy and not to try to get everything. Our time, energy an ...
- vonic单页面应用
Vonic—基于Vue.js和ionic样式的移动端UI框架 先放上源码和demo地址: 标签演示: https://wangdahoo.github.io/vonic/docs/ 源码 ...