手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >P3P Header解决Cookie跨域的问题
P3P Header解决Cookie跨域的问题
摘要:P3PP3P是一種被稱為個人隱私安全平臺項目(thePlatformforPrivaryPreferences)的標準,能夠保護在線隱私權,...

P3P

P3P是一種被稱為個人隱私安全平臺項目(the Platform for Privary Preferences)的標準,能夠保護在線隱私權,使Internet衝浪者可以選擇在瀏覽網頁時,是否被第三方收集並利用自己的個人信息。如果一個站點不遵守P3P標準的話,那麼有關它的Cookies將被自動拒絕,並且P3P還能夠自動識破多種Cookies的嵌入方式。P3P是由全球資訊聯盟網所開發的。

例子

當頁面存在iframe時,想要獲取iframe框架裏面的cookie,就要在iframe相應的動態頁面裏面添加P3P Header信息,否則在IE下獲取不到。因為IE有安全策略,限制頁面不保存第三方cookie(注:當前訪問頁面為第一方cookie,第三方cookie就是當前網頁以外的其他網頁的cookie)。

复制代码 代码如下:

<?php

//http://www.a.com/a_setcookie.php 文件内容:

setcookie("test", "testval", time()+3600, "/", ".a.com");

//http://www.a.com/a_getcookie.php 文件内容:

var_dump($_COOKIE);

/*-----------------------------------------------------------------------

http://www.b.com/b_setcookie.php 文件内容:

<iframe src="http://www.a.com/a_setcookie.php?id=www.b.com"></iframe>

通过浏览器访问: http://www.b.com/b_setcookie.php

http://www.a.com/a_getcookie.php在访问 b.com域后,我们并没有在 a.com域发现设置上cookie值。

将http://www.a.com/a_setcookie.php文件内容改为如下:

--------------------------------------------------------------------------*/

header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');

setcookie("test","testval", time()+3600, "/", ".a.com");

//再次访问:http://www.b.com/b_setcookie.php

//http://www.a.com/a_getcookie.php在访问b.com域后,设置了a.com域的cookie值。

JS使用P3P协议

复制代码 代码如下:

xmlhttp.setRequestHeader( "P3P" , 'CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"' );

【P3P Header解决Cookie跨域的问题】相关文章:

JS中的THIS和WINDOW.EVENT.SRCELEMENT详解

浅析javascript函数表达式

JS验证IP,子网掩码,网关和MAC的方法

解决未知尺寸的图片撑破页面的问题

JavaScript中的small()方法使用详解

优化RequireJS项目的相关技巧总结

js对象和json对象互相转换的问题

破解Session cookie的方法

多个iframe自动调整大小的问题

JS中Eval解析JSON字符串的一个小问题

精品推荐
分类导航