IE下Iframe跨域访问不能写cookie的解决方法

 最近做了一个系统,需要链入另外一个系统的页面,姑且称为 系统A 链入系统B的页面,采用iframe引用B的页面;

在测试环境的时候,访问一切正常;到了正式环境,发现有部分人在系统A访问iframe引用的 B系统的页面,出现session丢失的问题;

 

      比较两边环境,发现测试环境中系统A和B都在一个主机上,而正式环境系统A和系统B是分开部署的。而IE的iframe有一个很郁闷的事情,就是跨域访问的时候,第三方(被嵌入的页面)默认是不能写cookie的,导致了很经常出现的跨域访问session丢失的问题;以上就是一个例子;

 

      解决方法:

 

      第一种很简单:

           将系统B设置为可信站点。

 

      第二种:

           IE设置隐私策略:在Internet选项->隐私->高级,将“替代自动cookie处理”的选项打上,并“第一方cookie”和“第三方cookie” 都设置为 接受;如下图:

            

 

      第三种:

           在response的head上增加p3p协议;

           java:  增加一个filter ,在 doFilter 部分:

 

Java代码   收藏代码
  1. HttpServletResponse res = (HttpServletResponse) response;  
  2. res.setHeader("P3P","CP=CAO PSA OUR");  

          P3P 是什么,做什么用,google大神会告诉的很清楚,这里就不说了;

          头信息中增加p3p协议,通过google大神也能找到很多文章;

 

          这里就说一个事情,这个P3P的设置是放在被引用页面的系统(即上面的B系统)中的,这个要切记。。Y的,我就因为这个事情,在调用系统(A)折腾了2个小时;

 


     另:推荐 http://www.cnblogs.com/_franky/archive/2011/03/16/1985954.html ,其中对各个浏览器对p3p的支持 做了详细的说明;可以看看;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值