关于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 5昨天隆重推出--PHP 5/Zend Engine 2.0新特性
Oct 09 PHP
社区(php&&mysql)四
Oct 09 PHP
PHP中去除换行解决办法小结(PHP_EOL)
Nov 27 PHP
解决phpmyadmin中缺少mysqli扩展问题的方法
May 06 PHP
基于PHP+Ajax实现表单验证的详解
Jun 25 PHP
php 模拟post_验证页面的返回状态(实例讲解)
Oct 28 PHP
php实现mysql备份恢复分卷处理的方法
Dec 26 PHP
php简单获取文件扩展名的方法
Mar 24 PHP
php中二分法查找算法实例分析
Sep 22 PHP
PHP查看SSL证书信息的方法
Sep 22 PHP
PHP表单验证内容是否为空的实现代码
Nov 14 PHP
PHP如何使用array_unshift()在数组开头插入元素
Sep 01 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
合作指挥官:孟斯克
2020/03/16 星际争霸
PHP 字符串编码截取函数(兼容utf-8和gb2312)
2009/05/02 PHP
PHPnow安装服务[apache_pn]失败的问题的解决方法
2010/09/10 PHP
php表单转换textarea换行符的方法
2010/09/10 PHP
基于PHP的cURL快速入门教程 (小偷采集程序)
2011/06/02 PHP
php格式化金额函数分享
2015/02/02 PHP
PHP书写格式详解(必看)
2016/05/23 PHP
Symfony查询方法实例小结
2017/06/28 PHP
Laravel使用消息队列需要注意的一些问题
2017/12/13 PHP
PDO::query讲解
2019/01/29 PHP
用jquery实现下拉菜单效果的代码
2010/07/25 Javascript
基于jQuery实现图片的前进与后退功能
2013/04/24 Javascript
Jquery使用Firefox FireBug插件调试Ajax步骤讲解
2013/12/02 Javascript
jQuery中filter()方法用法实例
2015/01/06 Javascript
jQuery创建DOM元素实例解析
2015/01/19 Javascript
Jquery结合HTML5实现文件上传
2015/06/25 Javascript
jQuery form插件的使用之处理server返回的JSON, XML,HTML数据
2016/01/26 Javascript
jQuery+css实现的换页标签栏效果
2016/01/27 Javascript
Angularjs中的事件广播 —全面解析$broadcast,$emit,$on
2016/05/17 Javascript
基于Node.js的JavaScript项目构建工具gulp的使用教程
2016/05/20 Javascript
ng-options和ng-checked在表单中的高级运用(推荐)
2017/01/21 Javascript
layui table 参数设置方法
2018/08/14 Javascript
[01:02:30]Mineski vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第三场 8.22
2019/09/05 DOTA
Python环境下安装使用异步任务队列包Celery的基础教程
2016/05/07 Python
基于python爬虫数据处理(详解)
2017/06/10 Python
Python实现模拟分割大文件及多线程处理的方法
2017/10/10 Python
Python 3.6 -win64环境安装PIL模块的教程
2019/06/20 Python
Python3爬虫里关于识别微博宫格验证码的知识点详解
2020/07/30 Python
深入了解canvas在移动端绘制模糊的问题解决
2019/04/30 HTML / CSS
一级方程式赛车官方网上商店:F1 Store(支持中文)
2018/01/12 全球购物
巴西本土电商平台:Americanas
2020/06/21 全球购物
篮球比赛策划方案
2014/06/05 职场文书
镇副书记专题民主生活会对照检查材料思想汇报
2014/10/02 职场文书
拉贝日记观后感
2015/06/05 职场文书
2019年最新借条范本!
2019/07/08 职场文书
python单向链表实例详解
2022/05/25 Python