设为首页 收藏本站
查看: 746|回复: 0

[经验分享] 关于PHP的header("P3P: CP=CURa……")

[复制链接]

尚未签到

发表于 2015-8-29 13:52:41 | 显示全部楼层 |阅读模式
  对于IE来说(默认安全级别下),iframe、img、link等标签都是只发送session cookie(又叫 第一方cookie),拦截本地cookie发送(又叫第三方cookie)。当这些标签跨域引用一个页面,实际上是发起了一次GET请求。
如果这个跨域的请求,HTTP返回头中带有Set-Cookie
那么这个cookie对浏览器来说,实际上是无效的。
看如下测试
假设有 www.a.com    与 www.b.com
两个域
在 www.b.com 上有一个页面,其中包含一个指向 www.a.com
的iframe
http://www.b.com/test.html
的内容为:
----------------------------------------------------------------------
<iframe
width=300 height=300 src="http://www.a.com/test.php"
></iframe>
----------------------------------------------------------------------

http://www.a.com/test.php
是一个对 a.com 域设置
cookie的页面,其内容为:
----------------------------------------------------------------------
<?php
header("Set-Cookie:
test=axis; domain=.a.com;
path=/
");
?>
<script>
alert(document.cookie);
</script>
----------------------------------------------------------------------

此时我们请求
http://www.b.com/test.html , 他包含一个iframe,会去跨域请求 www.a.com/test.php ,该php页面会尝试
set-cookie
第一次请求, test.php 会 set-cookie,所以浏览器会收到一个cookie。
如果
set-cookie 成功,再次请求该页面,浏览器应该会 sent 刚才 recieve
到的cookie。可是由于前面说的跨域限制,在IE里的iframe标签是 set-cookie不成功的,所以无法sent刚才收到的cookie。
这里无论是 session cookie 还是本地cookie都是一样。
DSC0000.jpg
  可以看到,第二次发包,还是没能sent出去cookie
  但是这种情况在加入了P3P header 后会改变。
P3P
header允许跨域访问隐私数据,从而可以跨域set-cookie成功

我们修改
www.a.com/test.php




<?php
header("P3P: CP=CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR");
header("Set-Cookie: test=axis; expires=Sun, 23-Dec-2018 08:13:02 GMT; domain=.a.com; path=/");
?>
<script>
alert(document.cookie);
</script>
  
  再次访问两次上面的测试过程
DSC0001.jpg
  可以看到第二个包已经发送出了收到的cookie
而我们写的javascript也能够弹出cookie了。

值得注意的是,P3P
header只需要设置一次
,这样跟在这个P3P header后面的所有 set-cookie,都可以跨域访问了。也就是说: 被P3P header设置过一次后,之后的请求不再需要P3P
header,也能够在iframe里跨域发送这些cookie。

但是如果用 set-cookie
去改变设置好的cookie,则不再具有这种跨域访问特性。

P3P header
还有一个特点就是同一个包里只能设置一次,后面的P3P Header不会覆盖前面的P3P
header,浏览器只认第一个。
P3P 是 The Platform for Privacy
Preferences
的简称
更多具体的内容可以参阅W3C的标准 http://www.w3.org/TR/P3P/
在这里,我们看到的很乱的 P3P
header里的东西,都不知道是什么乱七八糟的策略内容,实际上这是一些简写
比如 上面用到的
P3P: CP=CURa ADMa
DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR
CP
是 Compact Policy 的简写
CURa 中 CUR 是 <current/> 的简写, a 是 always
的简写
当然P3P header也可以直接 引用一个 xml 策略文件
比如这么写

HTTP/1.1 200 OK
P3P: policyref="http://catalog.example.com/P3P/PolicyReferences.xml"
Content-Type: text/html
Content-Length: 7413
Server: CC-Galaxy/1.3.18
  使用P3P的方法还有很多,这里不一一列举了。

最后,利用P3P
Header 的这种特性,在实际攻击中,还是可以利用一下的。
比如利用CRLF插入一个P3P
header后,改变一个本地cookie的值,该cookie在之后的过程中可以被iframe引用到,也许会发生一些很奇妙的事情。
具体会变成什么样我也不知道,毕竟web应用安全和环境的关系是越来越紧密了。
  
  转自:
  关于PHP的header("P3P: CP=CURa……")
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-106003-1-1.html 上篇帖子: PHP输出缓存(output_buffering)小记 下篇帖子: PHP 堆栈与列队学习了··
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表