关于Iframe如何跨域访问Cookie和Session的解决方法


Posted in PHP onApril 15, 2013

最近做登录系统的整合,其中遇到的一个最关键的问题为在一个统一的后台里需要无障碍的访问另外一个系统后台,这个系统是第三方提供的一个加过密的系统,后台自动登录接口是自己分析出来的,没有单独提供,当从统一后台通过自动登录接口登录时,系统直接跳转到系统后台首页,后台登录成功后所跳转的URL这里没法指定,控制不了跳转的页面,如果在统一后台里需要链接到这个系统后台的另外一个页面,而非后台默认首页时,也就是将第三方系统后台的菜单功能放到我们这个统一后台里。

对于这样的一个需要,这里会遇到一个问题,为了能正常访问第三方系统的后台栏目,必需确保已经登录该系统,否则会提示用户登录,所以在点击这些菜单链接时,系统必需已经登录。

为了解决这个问题,在页面头部添加了一个不可见的iframe,使其指向到自动登录接口,这个接口如果正常通过浏览器地址栏访问,当用户名和密码验证无误时,会跳转到系统后台首页,由于此时放在了一个不可见的IFRAME中,所以跳转对当前后台页面没有任何影响。按照我的设计方法,系统应该就可以正常使用了。

但,既然说到但了,就说明肯定遇到了问题,不然这里不会来这么大的一个转折的。

但由于这里各系统均属于不同的系统,域名不一样,所以出现了Iframe在IE中,不能正常生成第三方系统Cookie的情况,但在Firefox和其它浏览器中均可生成,所以用IE访问时,总是跳转到登录页面。

这里需要说明一下,这里的第三方系统放在我们自己的服务器上的,只是所有源码加了密!

最后查阅了相关资料后,发现在IE中,为了安全,阻止了通过IFRAME生成第三方域的COOKIE,为了解决这个问题,MS规定只要在HTTP的HEADER头中,设定P3P这个头,就可以通过IFRAME来生成第三方COOKIE了。

PHP中,P3P HEADER 头的设置方法如下:

header(‘P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”‘);

注意:这里的P3P需要添加到第三方域生成Cookie的那个文件才生效,否则无济于事。

这里又有问题了,第三方系统生成COOKIE在后台的一个叫admin.php的页面里生成的,而这个页面又是加过密的,这可怎么办了,想了很久,最后同事灵机一动,说我们可以用我们自己的文件来包含它。靠,这方法太妙了,为什么我就没有想到了,同事真是太有才了,真是佩服的五体投地,当然,我对他这么一佩服,据他说自己当晚也自己佩服了自己一晚上。

所以最后的解决方案为将原来的admin.php文件命名为admin_2.php,然后新建admin.php,最后在这个文件中,添加上面所的P3P这个HEADER头,并再次包含 admin_2.php这个文件,最终代码如下:

header(‘P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”‘);
include “admin_2.php”;

最后,问题彻底解决!

这里标题是COOKIE和SESSION的问题,实质上,基本上是一回事,SEESION最终的保存也是通过SESSION_ID保存到COOKIE源码天空,然后通过这个SID到服务器上找相应的SEESION数据,只要把COOKIE里的SEESION_ID这个COOKIE给删掉,SESSION也就失效了。

PHP 相关文章推荐
php后台多用户权限组思路与实现程序代码分享
Feb 13 PHP
php+ajax做仿百度搜索下拉自动提示框(有实例)
Aug 21 PHP
Win下如何安装PHP的APC拓展
Aug 07 PHP
ThinkPHP3.1新特性之动态设置自动完成和自动验证示例
Jun 19 PHP
destoon找回管理员密码的方法
Jun 21 PHP
PHP+jQuery 注册模块的改进(一):验证码存入SESSION
Oct 14 PHP
PHP+jquery+ajax实现即时聊天功能实例
Dec 23 PHP
浅析php设计模式之数据对象映射模式
Mar 03 PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
Nov 13 PHP
php大小写转换函数(strtolower、strtoupper)用法介绍
Nov 17 PHP
laravel框架之数据库查出来的对象实现转化为数组
Oct 23 PHP
常见的5个PHP编码小陋习以及优化实例讲解
Feb 27 PHP
关于PHP的相似度计算函数:levenshtein的使用介绍
Apr 15 #PHP
关于PHP递归算法和应用方法介绍
Apr 15 #PHP
PHP 读取Postgresql中的数组
Apr 14 #PHP
php简单开启gzip压缩方法(zlib.output_compression)
Apr 13 #PHP
做了CDN获取用户真实IP的函数代码(PHP与Asp设置方式)
Apr 13 #PHP
php检测图片木马多进制编程实践
Apr 11 #PHP
谈谈关于php的优点与缺点
Apr 11 #PHP
You might like
php email邮箱正则
2008/10/08 PHP
php中substr()函数参数说明及用法实例
2014/11/15 PHP
PHP rsa加密解密使用方法
2015/04/27 PHP
PHP常用的小程序代码段
2015/11/14 PHP
PHP远程连接oracle数据库操作实现方法图文详解
2019/04/11 PHP
PHP 加密 Password Hashing API基础知识点
2020/03/02 PHP
XP折叠菜单&仿QQ2006菜单
2006/12/16 Javascript
javascript 设置文本框中焦点的位置
2009/11/20 Javascript
javascript 模拟JQuery的Ready方法实现并出现的问题
2009/12/06 Javascript
调试Node.JS的辅助工具(NodeWatcher)
2012/01/04 Javascript
html页面显示年月日时分秒和星期几的两种方式
2013/08/20 Javascript
jquery设置text的值示例(设置文本框 DIV 表单值)
2014/01/06 Javascript
js控制浏览器全屏示例代码
2014/02/20 Javascript
js定时器(执行一次、重复执行)
2014/03/07 Javascript
基于jQuery1.9版本如何判断浏览器版本类型
2016/01/12 Javascript
快速掌握Node.js环境的安装与运行方法
2016/02/16 Javascript
酷炫jQuery全屏3D焦点图动画效果
2016/03/22 Javascript
nodejs利用http模块实现银行卡所属银行查询和骚扰电话验证示例
2016/12/30 NodeJs
浅谈VUE防抖与节流的最佳解决方案(函数式组件)
2019/05/22 Javascript
详解Python中的静态方法与类成员方法
2017/02/28 Python
利用Django内置的认证视图实现用户密码重置功能详解
2017/11/24 Python
python实现录音小程序
2020/10/26 Python
pow在python中的含义及用法
2019/07/11 Python
Python中顺序表原理与实现方法详解
2019/12/03 Python
Python3.7 基于 pycryptodome 的AES加密解密、RSA加密解密、加签验签
2019/12/04 Python
pytorch nn.Conv2d()中的padding以及输出大小方式
2020/01/10 Python
django template实现定义临时变量,自定义赋值、自增实例
2020/07/12 Python
matplotlib设置颜色、标记、线条,让你的图像更加丰富(推荐)
2020/09/25 Python
在线购买世界上最好的酒:BoozeBud
2018/06/07 全球购物
英国排名第一的冲浪店:Ann’s Cottage
2020/06/21 全球购物
会走路的树教学反思
2014/02/20 职场文书
青春寄语大全
2014/04/09 职场文书
化工操作工岗位职责
2014/04/29 职场文书
五月的鲜花活动方案
2014/08/21 职场文书
思想作风建设心得体会
2014/10/22 职场文书
MySQL分布式恢复进阶
2022/07/23 MySQL