1.准备两个虚拟域名

127.0.0.1  www.openpoor.com

127.0.0.1  www.myspace.com

2.在openpoor的根目录下创建以下文件

index.PHP

[php] view plain copy

  1. <?php
  2. session_start();
  3. ?>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="UTF-8"/>
  8. <title>sync login</title>
  9. </head>
  10. <body>
  11. <?php if(empty($_SESSION['username'])):?>
  12. hello,游客;请先<a href="login.php">登录</a><a href="http://www.myspace.com/index.php">进入空间</a>
  13. <?php else: ?>
  14. hello,<?php echo $_SESSION['username']; ?>;<a href="http://www.myspace.com/index.php">进入空间</a>
  15. <?php endif; ?>
  16. <a href="http://www.openpoor.com/index.php">home</a>
  17. </body>
  18. </html>

login.php

[php] view plain copy

  1. <?php
  2. session_start();
  3. if(!empty($_POST['username'])){
  4. require '../Des.php';
  5. $_SESSION['username'] = $_POST['username'];
  6. $redirect = 'http://www.openpoor.com/index.php';
  7. header('Location:http://www.openpoor.com/sync.php?redirect='.urlencode($redirect).'&code='.Des::encrypt($_POST['username'],'openpoor'));exit;
  8. }
  9. ?>
  10. <!DOCTYPE html>
  11. <html>
  12. <head>
  13. <meta charset="UTF-8"/>
  14. <title>sync login</title>
  15. </head>
  16. <body>
  17. <form action="" method="post">
  18. <input type="text" name="username" placeholder="用户名"/>
  19. <input type="text" name="password" placeholder="密码"/>
  20. <input type="submit" value="登录"/>
  21. </form>
  22. </body>
  23. </html>

sync.php

[php] view plain copy

  1. <?php
  2. $redirect = empty($_GET['redirect']) ? 'www.openpoor.com' : $_GET['redirect'];
  3. if(empty($_GET['code'])){
  4. header('Loaction:http://'.urldecode($redirect));
  5. exit;
  6. }
  7. $apps = array(
  8. 'www.myspace.com/slogin.php'
  9. );
  10. ?>
  11. <!DOCTYPE html>
  12. <html>
  13. <head>
  14. <meta charset="UTF-8"/>
  15. <?php foreach($apps as $v): ?>
  16. <script type="text/javascript" src="http://<?php echo $v.'?code='.$_GET['code'] ?>"></script>
  17. <?php endforeach; ?>
  18. <title>passport</title>
  19. </head>
  20. <body>
  21. <script type="text/javascript">
  22. window.onload=function(){
  23. location.replace('<?php echo $redirect; ?>');
  24. }
  25. </script>
  26. </body>
  27. </html>

3.在myspace的根目录下创建如下文件

slogin文件 完成session的设置

[php] view plain copy

  1. <?php
  2. session_start();
  3. header('Content-Type:text/javascript; charset=utf-8');
  4. if(!empty($_GET['code'])){
  5. require '../Des.php';
  6. $username = Des::decrypt($_GET['code'],'openpoor');
  7. if(!empty($username)){
  8. header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');
  9. $_SESSION['username'] = $username;
  10. }
  11. }
  12. ?>

index.php

[php] view plain copy

  1. <?php
  2. session_start();
  3. if(!empty($_SESSION['username']))
  4. {
  5. echo "欢迎来到".$_SESSION['username']."的空间";
  6. }else{
  7. echo "请先登录";
  8. }
  9. ?>

4.Des.php的文件内容如下

[php] view plain copy

  1. <?php
  2. /**
  3. *@see Yii CSecurityManager;
  4. */
  5. class Des{
  6. public static function encrypt($data,$key){
  7. $module=mcrypt_module_open('des','', MCRYPT_MODE_CBC,'');
  8. $key=substr(md5($key),0,mcrypt_enc_get_key_size($module));
  9. srand();
  10. $iv=mcrypt_create_iv(mcrypt_enc_get_iv_size($module), MCRYPT_RAND);
  11. mcrypt_generic_init($module,$key,$iv);
  12. $encrypted=$iv.mcrypt_generic($module,$data);
  13. mcrypt_generic_deinit($module);
  14. mcrypt_module_close($module);
  15. return md5($data).'_'.base64_encode($encrypted);
  16. }
  17. public static function decrypt($data,$key){
  18. $_data = explode('_',$data,2);
  19. if(count($_data)<2){
  20. return false;
  21. }
  22. $data = base64_decode($_data[1]);
  23. $module=mcrypt_module_open('des','', MCRYPT_MODE_CBC,'');
  24. $key=substr(md5($key),0,mcrypt_enc_get_key_size($module));
  25. $ivSize=mcrypt_enc_get_iv_size($module);
  26. $iv=substr($data,0,$ivSize);
  27. mcrypt_generic_init($module,$key,$iv);
  28. $decrypted=mdecrypt_generic($module,substr($data,$ivSize,strlen($data)));
  29. mcrypt_generic_deinit($module);
  30. mcrypt_module_close($module);
  31. $decrypted = rtrim($decrypted,"\0");
  32. if($_data[0]!=md5($decrypted)){
  33. return false;
  34. }
  35. return $decrypted;
  36. }
  37. }
  38. ?>

当在openpoor登录后将session信息传到其他域名下的文件下进行处理,以script标签包含的形式进行运行。

5.此时访问www.openpoor.com和www.myspace.com都是未登录状态

登录后两个域名下都是登录状态

到此我们实现了一个简单的单点登录。

PHP 实现单点登录的更多相关文章

  1. 著名ERP厂商的SSO单点登录解决方案介绍一

          SSO英文全称Single Sign On,单点登录.SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可以将这次主要的登录映射到其他应用中用于同一个用户 ...

  2. 看图理解JWT如何用于单点登录

    单点登录是我比较喜欢的一个技术解决方案,一方面他能够提高产品使用的便利性,另一方面他分离了各个应用都需要的登录服务,对性能以及工作量都有好处.自从上次研究过JWT如何应用于会话管理,加之以前的项目中也 ...

  3. 细说SSO单点登录

    什么是SSO? 如果你已知道,请略过本节! SSO核心意义就一句话:一处登录,处处登录:一处注销,处处注销.即:在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. 很多人容易把SS ...

  4. [原创]django+ldap+memcache实现单点登录+统一认证

    前言 由于公司内部的系统越来越多,为了方便用户使用,通过django进行了单点登录和统一认证的尝试,目前实现了django项目的单点登录和非django项目的统一认证,中间波折挺多,涉及的技术包括dj ...

  5. [原创]django+ldap实现单点登录(装饰器和缓存)

    前言 参考本系列之前的文章,我们已经搭建了ldap并且可以通过django来操作ldap了,剩下的就是下游系统的接入了,现在的应用场景,我是分了2个层次,第一层次是统一认证,保证各个系统通过ldap来 ...

  6. CAS FOR WINDOW ACTIVE DIRECTORY SSO单点登录

    一.CAS是什么? CAS(Central Authentication Service)是 Yale 大学发起的一个企业级的.开源的项目,旨在为 Web 应用系统提供一种可靠的单点登录解决方法(支持 ...

  7. 单点登录改进版-使用ajax分发cookie避免重定向轮询

    前言 继上一篇博文:可跨域的单点登录(SSO)实现方案[附.net代码]虽然实现了单点登录,也存在很多不合理的地方.很多热心的朋友也给出了很多指导性的意见,特别是 LoveCoder提出的意见. 在很 ...

  8. 可跨域的单点登录(SSO)实现方案【附.net代码】

    SSO简介 定义: 传统的单站点登录访问授权机制是:登录成功后将用户信息保存在session中,sessionId保存在cookie中,每次访问需要登录访问的资源(url)时判断当前session是否 ...

  9. .net 单点登录实践

    前言 最近轮到我在小组晨会来分享知识点,突然想到单点登录,准备来分享下如何实现单点登录,所以有了下文.实现方案以及代码可能写得不是很严谨,有漏洞的地方或者错误的地方欢迎大家指正. 刚开始头脑中没有思路 ...

  10. asp.net mvc 权限过滤和单点登录(禁止重复登录)

    1.权限控制使用controller和 action来实现,权限方式有很多种,最近开发项目使用控制控制器方式实现代码如下 /// <summary> /// 用户权限控制 /// < ...

随机推荐

  1. ADB故障时的一些命令

    开发中经常用到adb重启等操作,简单记录一下. 1.重启 adb kill-server adb start-server 2.显示版本号 adb version 3.显示已连接的设备 adb dev ...

  2. 【LeetCode题解】21_合并两个有序链表

    目录 21_合并两个有序链表 描述 解法一:迭代 思路 Java 实现 Python 实现 解法二:递归 思路 Java 实现 Python 实现 21_合并两个有序链表 描述 将两个有序链表合并为一 ...

  3. java 使用 pdf.js 在线查看 pdf 文档

    1. 下载对应的 pdf.js 文件: 推荐地址:             https://github.com/mozilla/pdf.js/            http://mozilla.g ...

  4. HTTP协议以及HTTP请求中8种请求方法

    HTTP协议以及HTTP请求中8种请求方法 什么是协议? 协议,是指通信的双方,在通信流程或内容格式上,共同遵守的标准. 什么是http协议? http协议,是互联网中最常见的网络通信标准. http ...

  5. ASP.NET 之 MVC框架及搭建

    一.MVC简介 MVC:Model-View-Controller(模型-视图-控制器),MVC是一种软件开发架构模式. 1.模型(Model) 模型对象是实现应用程序数据域逻辑的应用程序部件. 通常 ...

  6. BASE64转文件下载

    你可以用HTML 5 注意:返回的文件数据必须是base 64编码的,因为您不能对二进制数据进行JSON编码 在我的AJAX我得到了如下的数据结构: <!DOCTYPE html> < ...

  7. Walkway.js – 创建简约的 SVG 线条动画

    Walkway.js 是一个使用线条和路径元素组成 SVG 动画图像的简单方法.只需根据提供的配置对象创建一个新的 Walkway 实例就可以了.这种效果特别适合那些崇尚简约设计风格的网页.目前, W ...

  8. 使用phpQuery轻松采集网页内容

    phpQuery是一个基于PHP的服务端开源项目,它可以让PHP开发人员轻松处理DOM文档内容,比如获取某新闻网站的头条信息.更有意思的是,它采用了jQuery的思想,你可以像使用jQuery一样处理 ...

  9. java 全自动生成Excel之ExcelUtil篇(上一篇的升级版 [针对实体类对象的遍历赋值])

    看了上一篇随笔之后可以对本篇有更好的了解! 使用的poi的jar包依然是上一篇的poi-3.17.jar.... import pojo.UserPojo(上一篇里有,这里就不粘贴了!) 不废话了,直 ...

  10. Spring系列之——使用了哪些设计模式

    1 工厂模式:BeanFactory.ApplicationContext创建中 2 模板模式:BeanFactory.ApplicationContext实现中 3 代理模式:在AOP实现中用到了J ...