架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 6638|回复: 0

[HTML/HTML5] sso单点登录同步登录/退出之p3p协议

[复制链接]
发表于 2018-5-24 15:32:12 | 显示全部楼层 |阅读模式
一、名词解释

P3P (The Platform for Privacy Preferences) W3C公布的一项隐私保护推荐标准,但是只有IE一家浏览器实现,其他浏览器基本上是不鸟这套标准。
第一方Cookie和第三方Cookie 假设http://a.com以iframe的形式嵌入http://b.comhttp://a.com的Cookie称为第一方Cookie,而http://b.com的Cookie称为第三方Cookie
二、P3P的应用场景

浏览器支持情况
P3P只有IE支持!(我测试谷歌浏览是支持p3p协议的,而且,从网上看到一般浏览器都支持P3P协议,我自己测试如下图

QQ截图20180524151642.jpg



应用场景
大部分浏览器,第一方Cookie肯定默认允许的。但是对于第三方Cookie的默认允许规则却差异很大。

对于IE浏览器:默认是不允许第三方Cookie的,http请求无法读取第三方cookie,这个时候就可以设置P3P协议头,就支持访问第三方Cookie。

对于Chrome,Firefox和Opera浏览器,默认都是允许第三方Cookie,即使手动禁掉第三方Cookie,http请求都还可以读取第三方Cookie。

对于Safari浏览器,默认是不允许第三方Cookie,但是http请求都还可以读取第三方Cookie。

三、回答你的问题

作用:IE浏览器默认不允许第三方Cookie,导致http请求无法访问第三方Cookie。
案例:假设 http://xxx.com使用iframe的形式嵌入http://yyy.comhttp://auth.yyy.com会对用户进行鉴权之后将sessionId写入cookie,http://pay.yyy.com将会读取该sessionId处理业务请求。但是对于IE用户如果没有设置P3P头的话,http://pay.yyy.com并不能读取到sessionId。

含义: 对于这样一个很坑爹的标准,其实大部分人都不太关注这个协议的具体含义,如果真的需要了解,可以参考 P3P1.0规范。
补充: 在前几年,还有很多因为P3P协议引发的线上问题血案,不过随着IE的份额越来越少,远离老版IE的用户越来越多(其实PC用户都越来越少...),P3P也会逐渐被人遗忘了... 对于大部分线上的站点来说:最简洁的写法 P3P:CP=. 最常用的写法 P3P:CP=CAO PSA OUR.

P3P协议介绍:https://www.w3.org/P3P/
P3P1.0规范链接:https://www.w3.org/TR/P3P/#compact_access




上一篇:vs2017 远程调试asp.net mvc网站项目
下一篇:php nginx用X-Accel-Redirect控制文件下载权限
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-21 00:34

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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