我让它工作了,但解决方案有点复杂,所以请耐心等待。
发生了什么
实际上,Internet Explorer对IFRAME页面的信任程度较低(IE称其为“第三方”内容)。如果IFRAME内的页面没有隐私政策,则其cookie将被阻止(状态栏中的眼睛图标表示,当您单击它时,它将显示被阻止的url列表)。
(来源:piskvor.org)
在这种情况下,当cookie被阻塞时,会话标识符不会发送,目标脚本抛出'session not found'错误。
(我已经尝试将会话标识符设置到表单中,并从POST变量加载它。这本来是可行的,但出于政治原因,我不能这么做。)
可以使IFRAME内的页面更加可信:如果内页发送带有IE可接受的隐私策略的P3P报头,则cookie将被接受。
如何解决
创建p3p策略
W3C教程是一个很好的起点。我已经浏览了它,下载了IBM隐私策略编辑器,并在那里创建了隐私策略的表示,并为它指定了一个名称以供引用(这里是policy1)。
注意:在这一点上,你实际上需要找出你的网站是否有隐私政策,如果没有,就创建它——它是否收集用户数据,什么样的数据,它用它做什么,谁可以访问它,等等。你需要找到这些信息并思考。仅仅把几个标签拼凑在一起是不够的。这一步不能纯粹在软件中完成,而且可能是高度政治化的(例如。“我们是否应该出售我们的点击统计数据?”)。
(如。“本网站由ACME有限公司运营,使用匿名的会话标识符进行操作,仅在明确允许的情况下收集用户数据,仅用于以下目的,仅在必要时存储数据,只有我们公司才能访问它,等等”)。
(使用此工具编辑时,可以查看策略中的错误/遗漏。同样非常有用的标签是“HTML策略”:在底部,它有一个“策略评估”-一个快速检查策略是否会被IE的默认设置阻止)
编辑器导出到.p3p文件,该文件是上述策略的XML表示形式。此外,它还可以导出该策略的“紧凑版本”。
链接到策略
然后需要一个政策参考文件(http://example.com/w3c/p3p.xml)(网站使用的隐私政策索引):
<META>
<POLICY-REFERENCES>
<POLICY-REF about="/w3c/example-com.p3p#policy1">
<INCLUDE>/</INCLUDE>
<COOKIE-INCLUDE/>
</POLICY-REF>
</POLICY-REFERENCES>
</META>
<INCLUDE>显示将使用此策略的所有uri(在我的示例中是整个站点)。我从Editor导出的策略文件上传到http://example.com/w3c/example-com.p3p
发送带有响应的压缩头
我已经在example.com设置了web服务器来发送带有响应的压缩头,就像这样:
HTTP/1.1 200 OK
P3P: policyref="/w3c/p3p.xml", CP="IDC DSP COR IVAi IVDi OUR TST"
// ... other headers and content
policyref是策略引用文件的相对URI(该文件又引用隐私策略),CP是紧凑的策略表示。请注意,示例中的P3P头的组合可能不适用于您的特定网站;您的P3P头必须如实代表您自己的隐私政策!
利润!
在此配置中,Evil Eye不会出现,cookie甚至保存在IFRAME中,应用程序可以正常工作。
编辑:不要做什么,除非你喜欢从诉讼中辩护
一些人建议“在你的P3P头中加入一些标签,直到邪恶之眼放弃”。
标签不仅仅是一堆比特,它们具有现实世界的含义,它们的使用赋予您现实世界的责任!
例如,假装您从未收集用户数据可能会让浏览器高兴,但如果您实际收集用户数据,P3P就与现实相冲突。简单地说,你是在故意欺骗你的用户,这在某些国家可能是犯罪行为。就像"进监狱,拿不到200美元"
以下是一些示例(完整的标签集请参阅p3pwriter):
NOI : "Web Site does not collected identified data." (as soon as there's any customization, a login, or any data collection (***** Analytics, anyone?), you must acknowledge it in your P3P)
STP: Information is retained to meet the stated purpose. This requires information to be discarded at the earliest time possible. Sites MUST have a retention policy that establishes a destruction time table. The retention policy MUST be included in or linked from the site's human-readable privacy policy." (so if you send STP but don't have a retention policy, you may be committing fraud. How cool is that? Not at all.)
我不是律师,但我不愿意去法庭上看看P3P头是否真的具有法律约束力,或者你是否可以在不愿意履行承诺的情况下向用户承诺任何东西。