PHP关于IE下的iframe跨域导致session丢失问题解决方法


Posted in PHP onOctober 10, 2013

今天搞的一个登录页面,被别的网站用iframe嵌进去后,死活无法登录(只在IE中存在这种情况)。

很明显,session无法被保存。但是直接在地址栏打开那个登录页面,一切都正常啊。真是奇怪啊。

在网上搜索了一下。发现这个问题还真有不少人提及到。最后的解决方法是在那个登录页面里加上以下代码:

<span style="font-family:Microsoft YaHei; font-size:14px">header('P3P: CP="ALL ADM DEV PSAi COM OUR OTRo STP IND ONL"'); 
session_start();</span>

可能这个问题跟我的登录页面是采用javascript的location跳转也有关。但没有深入测试研究。

以下是拓展阅读:

---------------------------------------------

今天在处理腾讯朋友应用的时候,测试给我发来个工单,说应用在IE7 上无法使用.出现登陆超时错误.

第一反应是session丢失了.

于是上网找了下 IE7 iframe session丢失问题.后来找到如下文章,问题解决:

=============================================

昨天,我在校内上做的时间日记终于上线了。上线第一天有80多个用户安装,但却以外收到不少用户的反馈说应用不可用。我之前都是在firefox上开发的(估计校内工作人员也是用firefox审核的),在使用IE7测试时,却发现首页之外的页面全都无法正常打开。

在网上查找了许多资料,发现在IE7中存在这样的问题:如果页面中存在着一个或多个iframe的子页面,那么在子页面中创建session可能无 法成功,这样session数据就无法和其他页面所共享。在开发校内、51应用时,假设采用iframe方式,很可能会遇到这样的问题。而且这个问题只存 在于IE7浏览器中,我在firefox, IE6和chrome等浏览器中测试均没有问题。

解决方案是:在运行session_start之前,在程序中加上如下一句(以php语言为例),大致是向浏览器声明一下安全级别,这样iframe子页面在创建session时就不会有问题了:

header('P3P: CP=”ALL ADM DEV PSAi COM OUR OTRo STP IND ONL”‘);

另外,我还了解到:如果二级域名中包含了下划线,如:your_domain.yourhost.com,在建立和传递session时也可能会出现问题。

一点感想:

1)时隔多年,浏览器兼容性问题仍然没有得到彻底解决,IE浏览器仍然是那么让开发者感到痛苦和折磨。
2)发布应用前,一定要经过严密的浏览器兼容性测试,否则就有可能损失应用的第一批用户。

==============================================

其他参考文章:

==============================================

解决iframe中jsessionid无法传递导致session丢失的问题

http://618119.com/archives/2007/12/19/48.html

在实现 ISMP2.1.1 接口的适合需要用到sso,而ISMP里定义的接口是需要在iframe等嵌入页面中调用sso接口,在实际开发中发现session无法正常传递。

重现问题的场景是:

1.先访问a站点:http://192.168.18.2/test.jsp

test.jsp的代码为:

<html> 
<head> 
<title> 618119.com </title> 
</head> 
<body> 
<iframe src=”http://192.168.18.3/sso.jsp?ssoinfo=xxxx “> 
</iframe> 
</body> 
</html>

sso .jsp里读取传递的ssoinfo,反向调用ISMP认证接口,

生成session,然后放入指定的属性值,

session .setAttribute(“ssoUser”,”lizongbo”);
页面再重定向到 http://192.168.18.3/iframe.jsp

response.sendRedirect(“/iframe.jsp”);

iframe.jsp中读取session中ssoUser的属性值,会发现无法读取。
2.如果先访问了 192.168.18.3的页面,再访问192.168.18.2的页面,此时的iframe嵌入是可以传递已生成好的jsessionid Cookie.

因此解决的办法有:

a.在url中加上jsessionid.

例如重定向到 response.sendRedirect(“/iframe.jsp;jsessionid =lizongbo”);
而这种情况下,如果iframe.jsp页面内的其它连接的url没有加上jsessionid,

也无法继续传递session,不过通过在客户端的js来为每个超连接的href属性重写加上jsessionid.

b.sso.jsp里设置P3P头信息
例如 P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”

或 P3P:CP=”CAO PSA OUR”

java代码为:

response.addHeader(“P3P”,”/”CAO PSA OUR/”");

PHP 相关文章推荐
杏林同学录(一)
Oct 09 PHP
php Http_Template_IT类库进行模板替换
Mar 19 PHP
phpMyAdmin 链接表的附加功能尚未激活问题的解决方法(已测)
Mar 27 PHP
PHP 查找字符串常用函数介绍
Jun 07 PHP
基于php使用memcache存储session的详解
Jun 25 PHP
smarty模板局部缓存方法使用示例
Jun 17 PHP
php获取百度收录、百度热词及百度快照的方法
Apr 02 PHP
PHP内核探索:哈希表碰撞攻击原理
Jul 31 PHP
php获取一定范围内取N个不重复的随机数
May 28 PHP
Laravel5.* 打印出执行的sql语句的方法
Jul 24 PHP
PHP 布尔值的自增与自减的实现方法
May 03 PHP
在phpstudy集成环境下的nginx服务器下配置url重写
Dec 02 PHP
php检测网页是否被百度收录的函数代码
Oct 09 #PHP
php MessagePack介绍
Oct 06 #PHP
php 批量替换程序的具体实现代码
Oct 04 #PHP
php5.5中类级别的常量使用介绍
Oct 02 #PHP
php mysql_real_escape_string函数用法与实例教程
Sep 30 #PHP
PHP文件上传主要代码讲解
Sep 30 #PHP
php中利用str_pad函数生成数字递增形式的产品编号
Sep 30 #PHP
You might like
php数组编码转换示例详解
2014/03/11 PHP
php禁止浏览器使用缓存页面的方法
2014/11/07 PHP
mysql alter table命令修改表结构实例详解
2016/09/24 PHP
关于PHP内置的字符串处理函数详解
2017/02/04 PHP
基于jquery的拖动布局插件
2011/11/25 Javascript
onmouseover和onmouseout的一些问题思考
2013/08/14 Javascript
js截取固定长度的中英文字符的简单实例
2013/11/22 Javascript
JS定时器实现数值从0到10来回变化
2016/12/09 Javascript
jQuery实现Table表格隔行变色及高亮显示当前选择行效果示例
2017/02/14 Javascript
js实现下拉菜单效果
2017/03/01 Javascript
分享十三个最佳JavaScript数据网格库
2017/04/07 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
vue-cli项目中怎么使用mock数据
2017/09/27 Javascript
详解如何在webpack中做预渲染降低首屏空白时间
2018/08/22 Javascript
Vue项目查看当前使用的elementUI版本的方法
2018/09/27 Javascript
详解React项目中碰到的IE问题
2019/03/14 Javascript
在vue中使用G2图表的示例代码
2019/03/19 Javascript
javascript面向对象创建对象的方式小结
2019/07/29 Javascript
jQuery实现图片随机切换、抽奖功能(实例代码)
2019/10/23 jQuery
windows下create-react-app 升级至3.3.1版本踩坑记
2020/02/17 Javascript
Ajax获取node服务器数据的完整步骤
2020/09/20 Javascript
vue 判断页面是首次进入还是再次刷新的实例
2020/11/05 Javascript
python调用java模块SmartXLS和jpype修改excel文件的方法
2015/04/28 Python
深入探究Python中变量的拷贝和作用域问题
2015/05/05 Python
Python中List.count()方法的使用教程
2015/05/20 Python
用Python的Django框架来制作一个RSS阅读器
2015/07/22 Python
深入解析Python设计模式编程中建造者模式的使用
2016/03/02 Python
Python 实现12306登录功能实例代码
2018/02/09 Python
python图形用户接口实例详解
2019/12/16 Python
python开发实例之python使用Websocket库开发简单聊天工具实例详解(python+Websocket+JS)
2020/03/18 Python
浅谈django 重载str 方法
2020/05/19 Python
Java中的异常处理机制的简单原理和应用
2013/04/27 面试题
中级会计职业生涯规划范文
2014/01/16 职场文书
大学生个人自荐信
2014/02/24 职场文书
介绍信应该怎么开?
2019/04/03 职场文书
go web 预防跨站脚本的实现方式
2021/06/11 Golang