关于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 相关文章推荐
wiki-shan写的php在线加密的解密程序
Sep 07 PHP
php 文件状态缓存带来的问题
Dec 14 PHP
修改PHP的memory_limit限制的方法分享
Feb 21 PHP
探讨:web上存漏洞及原理分析、防范方法
Jun 29 PHP
PHP使用stream_context_create()模拟POST/GET请求的方法
Apr 02 PHP
php实现当前页面点击下载文件的实例代码
Nov 16 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
Aug 29 PHP
详解thinkphp5+swoole实现异步邮件群发(SMTP方式)
Oct 13 PHP
laravel5实现微信第三方登录功能
Dec 06 PHP
PHP For循环字母A-Z当超过26个字母时输出AA,AB,AC
Feb 16 PHP
php 下 html5 XHR2 + FormData + File API 上传文件操作实例分析
Feb 28 PHP
PHP使用Redis队列执行定时任务实例讲解
Mar 24 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中使用Sockets 从Usenet中获取文件
2008/01/10 PHP
解决ThinkPHP关闭调试模式时报错的问题汇总
2015/04/22 PHP
ThinkPHP框架安全实现分析
2016/03/14 PHP
CentOS7系统搭建LAMP及更新PHP版本操作详解
2020/03/26 PHP
自适应图片大小的弹出窗口
2006/07/27 Javascript
js实现iframe动态调整高度的代码
2008/01/06 Javascript
JavaScript实用技巧(一)
2010/08/16 Javascript
深入理解JavaScript系列(15) 函数(Functions)
2012/04/12 Javascript
jQuery表格排序组件-tablesorter使用示例
2014/05/26 Javascript
Bootstrap入门书籍之(零)Bootstrap简介
2016/02/17 Javascript
对Angular.js Controller如何进行单元测试
2016/10/25 Javascript
微信小程序 支付功能开发错误总结
2017/02/21 Javascript
AngularJS $http模块POST请求实现
2017/04/08 Javascript
使用JavaScript实现链表的数据结构的代码
2017/08/02 Javascript
vue-cli3.0配置及使用注意事项详解
2018/09/05 Javascript
详解如何构建Promise队列实现异步函数顺序执行
2018/10/23 Javascript
Vue 幸运大转盘实现思路详解
2019/05/06 Javascript
D3.js 实现带伸缩时间轴拓扑图的示例代码
2020/01/20 Javascript
微信小程序实现电子签名并导出图片
2020/05/27 Javascript
解决谷歌搜索技术文章时打不开网页问题的python脚本
2013/02/10 Python
解决Python中由于logging模块误用导致的内存泄露
2015/04/23 Python
python paramiko利用sftp上传目录到远程的实例
2019/01/03 Python
python3常用的数据清洗方法(小结)
2019/10/31 Python
pytorch动态网络以及权重共享实例
2020/01/06 Python
基于Python爬取爱奇艺资源过程解析
2020/03/02 Python
python exit出错原因整理
2020/08/31 Python
Python字符串的15个基本操作(小结)
2021/02/03 Python
澳大利亚汽车零部件、音响及配件超市:Automotive Superstore
2018/06/19 全球购物
什么是Assembly(程序集)
2014/09/14 面试题
给水工程专业毕业生自荐信
2014/01/28 职场文书
缓刑人员思想汇报500字
2014/09/12 职场文书
2014年学生会生活部工作总结
2014/11/07 职场文书
特种设备安全管理制度
2015/08/06 职场文书
如何书写公司员工保密协议?
2019/06/27 职场文书
数据库连接池
2021/04/06 MySQL
Python使用BeautifulSoup4修改网页内容
2022/05/20 Python