前端单点登录(SSO)实现方法(二级域名与主域名)
1.单点登录介绍
单点登录 SSO 全称 Singn Sign On 。SSO 是指在多个应用系统中,用户只需要登录一次用户系统,就可以访问其他互相信任的应用系统。例如:在网易官网登录账户,那么再进入网易邮箱等其他业务的时候会自动登录。另外还有一个好处就是在一定时间内可以不用重复登录账户。
2.域名与跨域
域名:网络中的一个门牌号。如:www.baidu.com 就是一个域名。
域名分析:

跨域:不同域名之间的通信。
跨域分析:

同源策略:在同一域名下,文件是可以互相访问的。在跨域情况下,由于 JavaScript 的保护机制,会规定一个同源策略。同源策略就是限制一个源中加载文本或脚本与来自其他源中的资源的交互方式。同源:域名,协议,端口相同。在非同源情况下,在请求数据时会报错。
读写操作:
同域:可以进行任何的读写操作。
跨域:1、通常允许写操作,例:表单提交、重定向
2、外链接资源
a、css: <link ...>
b、js: <script ...> //错误信息,只会在同源脚本中打印出来
c、img: <image ..>
d、html5视频、音频 : <vedio> <audio>
e、<object> <embed> <applet>
f、@font-face //不同浏览器支持不同,有的支持跨域字体,有的仅支持同源字体
g、<frame> <iframe> 站点可以使用X-Frame-Options消息头来阻止这种形式的跨域交互。
3、通常不允许读操作
解决跨域通信的方法:
1. html5 possagemessage 2. jsonp 3.window.name
4.window.name 5.location.hash 6.cookie
3.单点登录实现一(二级域名情况)
二级域名单点登录情况:
例如: 需要在 bbb.a.com 和 ccc.a.com 实现单点登录
解决方法:
对于二级域名的单点登录,可以通过共享 cookie 来实现。当在 bbb.a.com 页面登录成功后,将一个可以验证已登陆的信息添加到 Cookie 当中。当然不能把密码账号添加到上面,不安全,不过也可以将密码与帐号先进行加密。需要注意设置 cookie 属性的 domain 为顶级域名,即 a.com 。对 cookie 设置不熟悉的可以使用 js-cookie 库来设置 cookie 。设置 cookie 后,在 ccc.a.com 中就可以检测是否登录过并获取 cookie 中先前设置好的属性来进行操作,进行发送请求验证等实现登录功能,直接完成 ccc.a.com 的登录。
操作流程:
1.用户在 bbb.a.com 登录。
2.将需要的身份验证信息存储到 cookie 中 (cookie 的 domain 属性设置顶级域名)。
3.用户进入 ccc.a.com 页面。
4.获取存储在 cookie 中的数据。:
5.ccc.a.com 将数据发送到后台服务器验证。
6.ccc.a.com 自动登录成功。
4.单点登录实现二(主域名)
主域名单点登录情况:
例如:需要再 www.aaa.com 和 www.bbb.com 实现单点登录
这种情况下不能共享 cookie 。这时需要利用 html5 中的 postMessage() 方法进行跨域传信息。
postMessage 简单使用介绍:
语法: otherWindow.postMessage(message, targetOrigin, [ transfer ])
参数: otherWindow: 需要传递参数的另一个窗口。
message: 要发送到另一个窗口的数据。
targetOrigin: 要发送数据的目标 url 。使用 * 代表任意目标。最好写完整协议,主机名,域名,端口。安全考虑。
transfer: 可选。是Transferable使用消息传送的一系列对象。不常用。
使用:例:父窗口(http://www.aaa.com)嵌套 iframe 子窗口(http://www.bbb.com)。
父窗口: window.frames[0].postMessage(message, "http://www.bbb.com");
子窗口: window.addEventListener("message", function(event){ if(event.origin !== "http://www.aaa.com") return; XXXX其他代码 }, false);
接受到 event 的参数: event.data: 从另一个端口传递来的数据。
event.origin: 发送信息的来源。一般需要判断来源。安全考虑。
event.source: 引用发送信息的对象。可以使用 event.source.postMessage() 向发送信息来的网站传递信息。
解决方法:使用一个中转网站用来转接数据。如使用 www.collect.com 来中转数据。将中转网站 www.collect.com 使用 iframe 嵌套进需要实现单点登录的网站(这里的嵌套没必要展示就设为 display: none)。这里需要实现的网站为 www.aaa.com 和 www.bbb.com 。当在 www.aaa.com 中登录帐号,将需要的验证信息存进 cookie 中,同时也将这些信息使用 postMessage 传递给子窗口即 www.collect.com 。www.collect.com 网站接受到这些信息后也存进 cookie 中。当在登录 www.bbb.com 时,嵌套的子窗口 www.collect.com 检测 cookie 信息若存在登录信息就使用 postMessage 传递这些 cookie 信息给父窗口 www.bbb.com 。www.bbb.com 收到信息就可以进行发送请求验证等实现登录功能,直接完成 www.bbb.com 的登录,同时也需要将这些信息存进 cookie 以给使用。
操作流程:
1.将 www.collect.com 嵌套进 www.aaa.com 和 www.bbb.com 中。
1.用户在 www.aaa.com 登录。
2.将需要的身份验证信息存储到 cookie 中。同时使用 postMessage 传给 www.collect.com。
3. www.collect.com 收到信息储存到 cookie 中,需要时调用。
3.用户进入 www.bbb.com 页面。
4.www.collect.com 获取存储在 cookie 中的数据,使用 postMessage 传给 www.bbb.com。
5.www.bbb.com 将数据发送到后台服务器验证。并将数据存进 cookie 。
6.www.bbb.com 自动登录成功。
参考文章:
1.postMessage:https://developer.mozilla.org/en-US/docs/Web/API/Window/postMessage
2.跨域:http://www.qdfuns.com/notes/17659/bb090a096034a8074332a5060e9b6a3c.html
3.cookie:http://blog.csdn.net/fangaoxin/article/details/6952954/
4.7种跨域方法:http://blog.csdn.net/super_yang_android/article/details/53992114
5.单点登录:http://blog.csdn.net/fay462298322/article/details/54963716
前端单点登录(SSO)实现方法(二级域名与主域名)的更多相关文章
- 初探单点登录 SSO
单点登录 单点登录(Single sign-on,SSO)是一种访问控制,在多个软件应用中,用户只需登录其中一个应用,就可以成功访问其他应用:同样,用户只需注销其中一个应用,就可以成功注销其他应用. ...
- 单点登录SSO原理
最近接触了一点单点登录的知识,有一点理解,记录一下.有些问题并没有找到完美的解决方法,还需要找点已有框架来看看. 欢迎留言探讨. 1 概念 1.1 概念及理解 有一个网上广为流传的 ...
- CAS单点登录(SSO)完整教程
转:http://blog.csdn.net/frinder/article/details/7969925 CAS单点登录(SSO)完整教程(2012-02-01更新) 一.教程说明 前言 教程目的 ...
- 单点登录SSO:图示和讲解
目录 概述 示例运行效果动画 跨域Web SSO时序图 代码截图 几个基本概念 涉及的站点和页面 重点理解:单点登录的核心步骤 敢说最准确的单点登录图示,因为: 我严格对照所画时序图的每个步骤,开发了 ...
- 单点登录(一)-----理论-----单点登录SSO的介绍和CAS+选型
什么是单点登录(SSO) 单点登录主要用于多系统集成,即在多个系统中,用户只需要到一个中央服务器登录一次即可访问这些系统中的任何一个,无须多次登录. 单点登录(Single Sign On),简称为 ...
- 聊聊单点登录(SSO)中的CAS认证
SSO介绍 背景 随着企业的发展,一个大型系统里可能包含 n 多子系统, 用户在操作不同的系统时,需要多次登录,很麻烦,我们需要一种全新的登录方式来实现多系统应用群的登录,这就是单点登录. web 系 ...
- cas单点登录 SSO 的实现原理
原文出处: cutesource 欢迎分享原创到伯乐头条 单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户 ...
- 单点登录 SSO 的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任. 单点登录在大型网站里使用 ...
- 十六、【适合中小企业的.Net轻量级开源框架】EnterpriseFrameWork框架核心类库之单点登录SSO
回<[开源]EnterpriseFrameWork框架系列文章索引> EFW框架源代码下载:http://pan.baidu.com/s/1qWJjo3U 单点登录(Single Sign ...
随机推荐
- webpack提取公共js代码
webpack打包js代码与提取公共js代码分析 webpack提取公共js代码示例 一.分析 webpack默认打包js代码时,是将从入口js模块开始,将入口js模块所依赖的js以及模块逐层依赖的模 ...
- linux(centos7) 查看磁盘空间大小
命令: df -hl 1 显示: 文件系统 容量 已用 可用 已用% 挂载点 Filesystem Size Used Avail Use% Mounted on /dev/hda2 45G 19G ...
- 终端复用工具-tmux
目录 终端复用工具--Tmux 一.为什么要用Tmux? 二.tmux是什么? 三.Tmux基本概念 四.Tmux使用规则 1.安装Tmux 2.基本使用 3.自定义配置文件 五.补充 1.tmux ...
- MacOs上的Intellij idea高频快捷键总结(2018.1版本)
高频快捷键 查找类快捷键 command + F12 查看当前类方法变量 command + E 查看最近文件 Alt+F1 ...
- IPC之namespace.c源码解读
// SPDX-License-Identifier: GPL-2.0 /* * linux/ipc/namespace.c * Copyright (C) 2006 Pavel Emelyanov ...
- Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported
Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported告诉你,你的请求头是application/x- ...
- 小程序UI设计(9)-文字排版
小程序中一般很少大段落的文字,基本是4.5个字的主题.一行标题.一行摘要.两行描述.显示时超出部分用省略号代替.下面结合工具使用介绍一下文字排版的方法.先看效果图. 工具中属性设置如下图:两行文字属 ...
- 异步消息处理机制相关面试问题-handler面试问题详解
什么是handler? 这个异常应该也就是引出handler的原因,也就是默认在非UI线程中是无法去更新UI的东东滴,那到底什么上handler呢? handler通过发送和处理Message和Run ...
- Linux之vim文本编译器
Vim是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用.和Emacs并列成为类Unix系统用户最喜欢的编辑器. [root@izwz98re ...
- 为什么JAVA对象需要实现序列化?
https://blog.csdn.net/yaomingyang/article/details/79321939 序列化是一种用来处理对象流的机制. 所谓对象流:就是将对象的内容进行流化.可以对流 ...