文档章节

PHP单点登录

 蜗牛奔跑
发布于 2016/11/20 23:22
字数 1073
阅读 52
收藏 1
点赞 0
评论 0

之前回答过同样的问题,我重新拿出来再回答一遍。题主请看

首先提醒一下题主不要被新技术吓到了,也不要去查什么SSO(Single Sign On,单点登录),那样只能增大你问题的复杂度和对这个问题的恐惧心理,其实真的没那么难。

我来帮你拆解下问题,你说的Session多端登录,其实可以拆解为Session共享+登录,不是什么高级的东西,无非是需要的Session值在让不同服务器不同域名的情况下都可以访问,让大家都读取同一个Session值,重要的是同一个session_id()值。这样的话,每台(服务器/项目)读取的都是同样的数据,既然都是读取同样的数据(尤其读取同样的session_id()值),那么我们不就可以凭借此标识符让不同用户显示不同的内容,多点登陆的问题不就解决了

(把问题简化,登录对于用户看来是一个特别的过程,在我们开发者看来无非就是让不同的人读取到不同的数据而已,而我们只需要获取那个登陆标识符即可)。

也就是说,session共享的关键技术点在于两点:

1. 让客户端访问同一个sessionId,
2. 让所有域名对应的服务器访问的Session的数据的位置必须一致

下面重点讲讲实现,Session共享相对于Cookie共享来说较为复杂,因为情况相对于比较多,大概有四种情况

同服务器同域名,同服务器不同域名,不同服务器同域名,不同服务器不同域名。

同服务器同域名(不同子域名)的实现:

实现比较简单,直接找一份网上的demo(图侵删),直接按照以下的代码实现即可。

同服务器不同域名的实现:

这种情况下,我们再次明确实现session共享的关键技术点,同一个sessionId同样的数据源
不同域名的话就要先将cookie('PHPSESSID')跨域,然后通过这个sessionid值从MySQL数据库或者Nosql中取得对应数据,这样就实现了同服务器不同域名的session共享。
首先是cookie跨域:

然后是Redis数据共享,key就是session_id,值就是需要共享的数据,使用到的就是Redis的集群技术,实例过于复杂,感兴趣的可以直接去文章查看:redis cluster 集群 安装 配置 详解

不同服务器同域名的实现:

此种情况与<同服务器不同域名的实现>差不多,但在此种情况下不需要考虑cookie跨域的问题了,那么着重实现数据共享即可,同上,key为sessio_id,值为具体的数据值,参考文章同上redis cluster 集群 安装 配置 详解

不同服务器名不同域名的实现:

此种情况和<同服务器不同域名的实现>图探访,也是要实现两个目标,同一个sessionId同样的数据源。不同域名的话就要先将cookie('PHPSESSID')跨域,然后通过这个sessionid值从MySQL数据库或者Nosql中取得对应数据,这样就实现了同服务器不同域名的session共享。
首先是cookie跨域:

然后是Redis数据共享,key就是session_id,值就是需要共享的数据,使用到的就是Redis的集群技术,实例过于复杂,感兴趣的可以直接去文章查看:redis cluster 集群 安装 配置 详解

我们发现四种情况下的解决方式都差不多,第2种情况<同服务器不同域名的实现>和第四种情况<不同域名不同服务器的实现>更是基本一样,其中的核心思想无非就是解决两个根源问题,session_id大家需要获取同一个,有一个共享的数据源需要给大家获取。

搞明白了这两点,Session共享的SSO也就水到渠成了。有疑惑可直接在评论区询问,我会立即回答。

本文转载自:

共有 人打赏支持
粉丝 34
博文 596
码字总数 114025
作品 0
海淀
php单点登录SSO

单点登录步骤: 用户访问应用程序a.com 应用程序a.com重定向到login.com(认证中心)并带上对应的应用程序地址 login.com进行数据认证 login.com返回到a.com后面加上一个ticket(令牌) a.com服务...

蜗牛奔跑 ⋅ 2015/10/27 ⋅ 0

Baigo SSO v1.2 发布,单点登录系统

单点登录系统 Baigo SSO v1.2 发布了,更新如下: -------------------v1.2------------------- 2016-09-06 示例代码位于 ./example 目录,不再提供 sdk 2016-09-01 改善判断是否为空的函数 ...

baigoStudio ⋅ 2016/09/06 ⋅ 5

baigo SSO v2.2 发布,单点登录系统

单点登录系统 baigo SSO v2.2 已发布,包含以下更新内容: -------------------v2.2------------------- 2017-10-28 优化模板及语言调度方式 优化帮助信息调度方式 2017-09-11 修复部分帮助信...

baigoStudio ⋅ 2017/11/28 ⋅ 0

折衷的方式实现php与ruby共享session实现单点登录

1.背景 前一阵部门要做一个内部讨论区,希望能和原有的gitlab集成在一起。 discuz虽然成熟但是感觉不够高大上,找了几个ruby的论坛discourse,rabel虽然时髦值够了但是成熟度又缺了点,最后选...

游鱼彩虹 ⋅ 2016/12/15 ⋅ 0

如何使用邮件系统“单点登录”功能

相信我们每个人都有这样的经历,比方说银行卡多的人要具体记忆每张卡的密码挺麻烦;现代人兴 趣广泛,爱好多多,运动健身俱乐部、娱乐游戏休闲、购物理财等各种场合少不了获得入门的“通行证...

umailserver ⋅ 2014/06/26 ⋅ 0

单点登录系统--baigoSSO

baigoSSO 是 PHP 开发的单点登录系统。 崇尚简单 baigo SSO 以简单为设计、开发的宗旨,安装部署简单、使用简单。baigo SSO 没有复杂的菜单,没有深奥的概念,没有晦涩难懂的名词,一切崇尚简...

baigoStudio ⋅ 2015/10/19 ⋅ 11

PHP版单点登陆实现方案

PHP版单点登陆实现方案,利用webservice,session,cookie技术,来进行通用的单点登录系统的分析与设 2011-05-17 15:38

kisshua ⋅ 2012/04/18 ⋅ 3

【转】Yale_CAS客户端配置说明

Java Web应用 使用cas-client-3.1.12 Java 设置filter <!-- 用于单点退出,该过滤器用于实现单点登出功能,可选配置--> <listener> <listener-class>org.jasig.cas.client.session.SingleSig......

leiboo ⋅ 2014/04/21 ⋅ 0

谁使用过“天天团购系统”啊?想跟CAS整合,可是不知道怎么在PHP文件中写接口

网上只有CAS的PHP接口,将文件拷贝到PHP系统就可以实现单点登录了,可是那只适用于简单的登录页面啊。像天天团购系统,本身也应该要写个接口吧。本人对PHP不熟,望指教!

葡萄枝 ⋅ 2014/02/18 ⋅ 3

Baigo SSO v1.1.5 发布,单点登录系统

-------------------v1.1.5------------------- 2016-08-09 简化同步登录 api 参数,并将同步登录接口调用方式更改为 post 改进了令牌生成方式,减少出错几率 2016-07-21 baigoValidator 升级...

baigoStudio ⋅ 2016/08/09 ⋅ 4

没有更多内容

加载失败,请刷新页面

加载更多

下一页

解决httpclient超时设置不生效的问题

最近公司有项目需要通过http调用第三方服务,且第三方服务偶有超时,故需要设置一定的超时时间防止不响应的情况出现。 初始设置如下: [java] view plain copy //超时设置 RequestConfig re...

Mr_Tea伯奕 ⋅ 7分钟前 ⋅ 0

过滤器Filter和拦截器HandlerInterceptor

过滤器 依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要...

hutaishi ⋅ 12分钟前 ⋅ 0

Redis入门详解(转)

Redis入门详解 Redis简介 Redis安装 Redis配置 Redis数据类型 Redis功能 持久化 主从复制 事务支持 发布订阅 管道 虚拟内存 Redis性能 Redis部署 Redis应用场景 Redis总结 Redis简介: Redi...

xiaoyaoyoufang ⋅ 24分钟前 ⋅ 0

说说javascript中的那些专业名词

DOM(Document Object Model) 文档对象模型 BOM(Browser Object Model) 浏览器对象模型 ECMA(European Computer Manufacturer's Association) 欧洲计算机制造商协会 W3C(World Wide Web Conso......

hang1989 ⋅ 44分钟前 ⋅ 0

Bootstrap Wizard 多步表单控件

废话 有一块需求是 有多步表单 点击下一步时触发验证一个范围内的表单,点击上一步或取消,清空表单并返回第一步,点击最后一步提交整个表单的 就找到了这个插件,本来自己写了一个原生的 fo...

无极之岚 ⋅ 今天 ⋅ 0

如何利用Spring Cloud构建起自我修复型分布式系统

利用Netflix所打造的组件及各类大家熟知的工具,我们完全可以顺利应对由微服务以及分布式计算所带来的技术挑战。 在过去一年当中,微服务已经成为软件架构领域一个炙手可热的新名词,而且我们...

harries ⋅ 今天 ⋅ 0

临近实习前的感想

再过两星期就要开始新的一段实习了,想想去年的这个时候也在实习,心中不免思绪万千,也一直想写对2017做个总结,但一直迟迟没有下笔。 2017年的春节,我就开始准备开学后找份实习。那时候就...

无精疯 ⋅ 今天 ⋅ 0

Spring AOP(面向切面编程)

Spring AOP概念: Spring AOP 可以劫持一个执行的方法,在方法执行之前或之后添加额外的功能。通常情况下,AOP把项目中需要在多处用到的功能,比如日志、安全和事物等集中到一个类中处理,而...

霍淇滨 ⋅ 今天 ⋅ 0

人工智能、机器学习、数据挖掘以及数据分析有什么联系?

人工智能是目前炙手可热的一个领域,所有的互联网公司以及各路大迦们纷纷表态人工智能将是下一个时代的革命性技术,可与互联网、移动互联网时代的变更相媲美;AlphaGo在围棋领域战胜人类最顶...

董黎明 ⋅ 今天 ⋅ 0

使用 vue-cli 搭建项目

vue-cli 是一个官方发布 vue.js 项目脚手架,使用 vue-cli 可以快速创建 vue 项目,GitHub地址是:https://github.com/vuejs/vue-cli 一、 安装 node.js 首先需要安装node环境,可以直接到中...

初学者的优化 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部