- 原文地址 : http://tw5566.iteye.com/blog/1945825
-
- 采用的p3p技术,实现原理,在访问网站x.com的时候,y.com程序触发y.com文件的写入sessionid值,sessionid值便可以获取,然后把seesion值存入数据库,取相同的sessionid值便可。这就要求y.com里面的程序文件必需能跨域访问,默认情况下,浏览器是不能跨域设置cookie的,加上p3p头后才行。在对应php文件加上:
- PHP Code复制内容到剪贴板
- header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');
- 这里直接引用网上的一篇博文了:
- 127.0.0.1 www.a.com
- 127.0.0.1 www.b.com
- 首先:创建 a_setcookie.php 文件,内容如下:
- <?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", $_GET['id'], time()+3600, "/", ".a.com");
- ?>
- 然后:创建 a_getcookie.php 文件,内容如下:
- <?php
- var_dump($_COOKIE);
- ?>
- 最后:创建 b_setcookie.php 文件,内容如下:
- <script src="http://www.a.com/a_setcookie.php?id=www.b.com"></script>
- ----------------------------
- 三个文件创建完毕后,我们通过浏览器依次访问:
- http://www.b.com/b_setcookie.php
- http://www.a.com/a_getcookie.php
- 我们会发现,在访问b.com域的时候,我们并没有在a.com域设置上cookie值。去掉重新访问两文件设置成功
p3p跨域详解
最新推荐文章于 2025-01-15 21:48:50 发布