javascript – 在safari上的facebook app iframe登录问题

我有一个使用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"')
?>

而已!

点赞