IE iframe cookie session丢失问题【转】
http://www.php-oa.com/2008/05/13/iframezhongkuayuchuandicookie.html
晕掉,IE真是超级破,还好我二年没用它了(用了二年linux做桌面).这次一个大问题,客户的一台主页使用了frame的方法来固定自己的域名指向一个二级,为了让用户看起来更加好.
但发现很多用户不能登陆,但有的用户也能登陆(现在才清楚能上的都是firefox)。查了好久,后来发现原来是IE有个叫P3P(The Platform for Privacy Preferences)隐私参数选择平台,这样的一个超强的功能.
在frameset里面,也就是里面的frame是来自第三方站点(不同IP或不同域名),那么默认情况下IE会自动禁用这些站点的cookie,也就是在请求某url时在HTTP header里不发送它们的cookie,包括session的cookie。注意,这些站点在response里面设置的cookie还是会被发送到浏览器的。
但象IE 6.0和IE 7.0有个自己的标准.要支持P3P,IE 6的缺省隐私等级设置为”中”——即”阻止没有合同隐私策略的第三方cookie”。而在用户浏览a.php时 A.com写入的为第一方Cookie,其嵌入的iframe指向b.php.这时B.com写入的就为第三方Cookie了,所以它是被IE当在了大门外。
所以,每次当用户提交的cookie提交时,就挂掉了.因为传不到真实的服务器.
好了,不多讲了,直接讲解决方案.
PHP的程序
可以直接在B网站中写入
<?php
header(‘P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”’)
?>
这样就能接受第三方的Cookie啦。
lighttpd的服务器
server.modules = (“mod_setenv”)
setenv.add-response-header = ( “P3P” => “CP=’CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR’”)
apache的服务器
<VirtualHost>
Header set P3P ‘CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”’
</VirtualHost>
IIS的服务器
增加一个网站http头来解决问题;
管理工具——〉选择一个网站——〉属性——〉http头,增加一个http头
然后输入头名:P3P
输入头内容:CP=CAO PSA OUR
- 下一篇: MySQL单机多实例方案【转】
- 上一篇: PHP5.4改变的新特性(未完待续)
相关推荐
- Lua在linux下的安装[Lua研究一]
- Posted on 03月08日
- 我的老屋
- Posted on 09月13日
- 《使用HTML、CSS和JavaScript开发Android程序》初读
- Posted on 09月05日
- 《构建高性能web站点》分布式缓存
- Posted on 05月02日
那法院里旁听席上坐的人是谁?无非就是一个露天一个不露天而已。这居然都能喷。
1ssssssssssssssssss