我有一个使用iframe的Facebook应用程序.
Facebook将我的网站加载到iframe中.当我点击链接时,我的网站使用灯箱显示iframe以显示Facebook登录信息.一切都在ff上工作正常,即铬.在safari上,帧会无限重新加载.
PHP代码
$me = null;
$session = $facebook->getSession();
if ($session) {
try {
$me = $facebook->api('/me');
$_SESSION['facebook'] = $me;
} catch (FacebookApiException $e) {
}
}
if($me) require_once("logged.php");
else require_once("login.php");
login.php中的javascript
window.fbAsyncInit = function() {
FB.init({
appId : '<?=$appId?>',
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
check_login_session();
// whenever the user logs in, we refresh the page
FB.Event.subscribe('auth.login', function() {
$.browser.safari = ( $.browser.safari && /chrome/.test(navigator.userAgent.toLowerCase()) ) ? false : true;
window.location.href = window.location.href;
});
};
任何想法,将不胜感激!
谢谢!
最佳答案 如果您仍在寻找解决方案,请尝试构建P3P标头
http://www.p3pwriter.com/LRN_121.asp
通常在iframe中设置cookie时存在安全问题,p3p标头充当网站与客户端计算机之间的协议,保证cookie中保存的信息不会被滥用.
快速解决方案:http://planet.admon.org/how-to-implement-p3p-http-headers-for-cross-site-cookies/
该怎么办:
复制粘贴到标题中:
<?php
header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"')
?>
而已!