阿飞小站

低调做事,高调做人!

导航

  • 首页
  • 搜索
  • 标签
  • 留言
  • 相册
« 最新LeapFTP 3.0注册码VANCL »

用P3P header解决iframe跨域访问cookie/session

At 5/19/2009 By 阿飞  

理论很简单,而且模式也和大多请求返回状态的SSO差不多,但是有几个地方是要注意一下的。

1.页面里的COOKIE不能是浏览器进程的COOKIE(包括验证票和不设置超时时间的COOKIE),,否则跨域会取不到.这点做跨域COOKIE的人比较少提到。不过实际上留意下几家大学做的方案,有细微的提到他们的验证模块里的COOKIE是有设置超时时间的;

2.当利用IFRAME时,记得要在相应的动态页的页头添加一下P3P的信息,否则IE会自觉的把IFRAME框里的COOKIE给阻止掉,产生问题.本身不保存自然就取不到了。这个其实是FRAMESET和COOKIE的问题,用FRAME或者IFRAME都会遇到;

3.测试时输出TRACE,会减少很多测试的工作量。

只需要设置 P3P HTTP Header,在隐含 iframe 里面跨域设置 cookie 就可以成功。他们所用的内容是:
P3P: CP='CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR'

ASP直接在头部加了头部申明,测试有效。
<%Response.AddHeader "P3P", "CP=CAO PSA OUR"%>

php的话,我没去试,应该是如下写法:
header('P3P: CP=CAO PSA OUR');

ASP.NET的话
通过在代码上加Response.AddHeader("P3P", "CP=CAO PSA OUR")或者在Window服务中将ASP.NET State Service 启动。

JSP:
response.setHeader("P3P","CP=CAO PSA OUR")

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

Comments

Previous

Powered By Z-Blog 1.8 Spirit Build 80722
Copyright © Www.ChengFei.Net. All Rights Reserved. 皖ICP备07003132号