本系列将由浅入深的结合示例、源码以及演示视频,手把手的带大家深入最新的单点登录SSO方案选型与架构开发实战。文末附5个满足不同单点登录场景的gif动画演示(如果看不清请在图片上右键用新窗口打开),本系列后继文章会深入它们的实现方式以及适用场景,大家也可以先观看揣摩其实现。

单点登录即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),加之实施人员对产品熟悉程度不一,导致企业稍有自身特定的情况,就会要花费大量工时研究调整,甚至最终无法按需交付。

先来几组单点登录方案演示吧,本系列后继文章会深入它们的具体实现方式以及适用场景。

演示一:零改造实施CSDN、百度单点登录

演示二: 任意入口登录、注销,均同步在所有站点登录、注销

演示三:集成AD认证

演示四:QQ、VPN客户端及Web站点统一单点登录

演示五:跨平台示例,移动端单点登录

手把手教做单点登录(SSO)系列之一:概述与示例的更多相关文章

  1. 最准确的单点登录SSO图示和讲解(有代码范例)|手把手教做单点登录(SSO)系列之二

    写第一篇博客<手把手教做单点登录(SSO)系列之一:概述与示例>,就获得了园子里朋友们热情的评论和推荐,感谢各位. 我那篇文章同时发了CSDN和博客园.对比一下,更感受到博客园童鞋们的技术 ...

  2. 单点登录SSO:可一键运行的完整代码

    单点登录方案不同于一个普通站点,它的部署比较繁琐:涉及到好几个站点,要改host.安装证书.配置HTTPS. 看到的不少这方面示例都是基于HTTP的,不认同这种简化: 1. 它体现不出混合HTTP/H ...

  3. 单点登录SSO:图示和讲解

    目录 概述 示例运行效果动画 跨域Web SSO时序图 代码截图 几个基本概念 涉及的站点和页面 重点理解:单点登录的核心步骤 敢说最准确的单点登录图示,因为: 我严格对照所画时序图的每个步骤,开发了 ...

  4. 单点登录SSO:概述与示例

    目录 概述 演示一:零改造实施单点登录 演示二: 单点注销 演示三:集成AD认证 演示四:客户端单点登录 演示五:移动端单点登录 单点登录SSO概述 本系列将由浅入深的,带大家掌握最新单点登录SSO方 ...

  5. [转载]单点登录SSO:概述与示例

    原文地址: https://www.cnblogs.com/baibaomen/p/sso.html 目录 概述 演示一:零改造实施单点登录 演示二: 单点注销 演示三:集成AD认证 演示四:客户端单 ...

  6. 基于IdentityServer4的OIDC实现单点登录(SSO)原理简析

    写着前面 IdentityServer4的学习断断续续,兜兜转转,走了不少弯路,也花了不少时间.可能是因为没有阅读源码,也没有特别系统的学习资料,相关文章很多园子里的大佬都有涉及,有系列文章,比如: ...

  7. Atitit. 单点登录sso 的解决方案 总结

    Atitit.  单点登录sso 的解决方案 总结 1. 系统应用场景and SSO模式选型 2 2. 系统应用的原则与要求 2 2.1. 开发快速简单::绝大部分系统来说,开发快速简单为主 2 2. ...

  8. 十六、【适合中小企业的.Net轻量级开源框架】EnterpriseFrameWork框架核心类库之单点登录SSO

    回<[开源]EnterpriseFrameWork框架系列文章索引> EFW框架源代码下载:http://pan.baidu.com/s/1qWJjo3U 单点登录(Single Sign ...

  9. CAS单点登录(SSO)完整教程

    转:http://blog.csdn.net/frinder/article/details/7969925 CAS单点登录(SSO)完整教程(2012-02-01更新) 一.教程说明 前言 教程目的 ...

随机推荐

  1. NDK 开发实例二(添加 Eigen库)

    上一篇,我已经阐述了如何创建一个简单的NDK实例: NDK 开发实例一(Android.mk环境配置下) 在上一篇的基础上,我们来添加Eigen库,然后做一个简单实例. Eigen是一个高层次的C + ...

  2. Python的.py文件打包成exe可执行文件

    前几天做了几个简单的爬虫python程序,于是就想做个窗口看看效果. 首先是,窗口的话,以前没怎么接触过,就先考虑用Qt制作简单的ui.这里用前面sinanews的爬虫脚本为例,制作一个获取当天sin ...

  3. BootStrap入门教程 (三)

    本文转自 http://www.cnblogs.com/ventlam/archive/2012/06/05/2524966.html 上讲回顾:Bootstrap的基础CSS(Base CSS)提供 ...

  4. 英文单词断行问题:CSS中word-break、word-wrap以及hyphens的兼容性和区别

    CSS中一提到单词断行,最先映入脑海的肯定是word-break和word-wrap这两条属性.但对于这两条属性到底有什么区别,兼容性如何,我一直都概念模糊.今天抽空把它们以及CSS3中新加入的断行属 ...

  5. 利用shell实现批量添加用户

    批量添加用户并设置随机密码,把添加的用户的名字和密码保存到文件中. [root@lamp scripts]# cat user.sh #!/bin/sh ` do pass=$(-) //取随机数的方 ...

  6. 在腾讯云上部署Hexo博客

    推荐理由 ----搭建个人的空间博客目前深受个人开发者的追捧,然而博客的种类和平台有很多,Hexo是一个开源的静态博客生成器.相比于其他博客而言它只要是web容器就能用.除了闷头专研技术之外,程序员还 ...

  7. React虚拟DOM具体实现——利用节点json描述还原dom结构

    前两天,帮朋友解决一个问题: ajax请求得到的数据,是一个对象数组,每个对象中,具有三个属性,parentId,id,name,然后根据这个数据生成对应的结构. 刚好最近在看React,并且了解到其 ...

  8. PRINCE2 有级别吗?

    PRINCE2是分级别的,有基础级和专业级两个级别 Foundation基础级考试没有报考条件限制, 完全根据学员掌握知识的能力和实际工作经验 Practitioner 专业级考试不可越级 1.持有P ...

  9. smartGWT DataSource数据动态加载

    昨天和今天早上,用DataSource从数据库后台动态加载数据,我的业务是这样的: 我有两个SelectItem选择框,第一个选择框里面的数据是单位,第二个选择框中的数据是对应单位的人,因为人可能有重 ...

  10. IOS开发创建开发证书及发布App应用(六)——打包应用

    6.打包应用 如下图,生成之后点击下面红框的按钮,按时间排序,然后点最新的一次生成 从右侧生成日志中找到如下图红框标识的部分,找到 -output ,把下面浅蓝色选中,这是app生成的文件夹路径 点击 ...