私は Facebook 用のアプリを作成し、Facebook PHP SDK と Javascript SDK を使用しています。
私の問題は、ログインボタンをクリックした後、Firefoxがページをリロードせず、リロードするアクションを確認するメッセージが表示されることです。何も起こらないことを確認した後、ページを手動でリロードする必要があります。Internet Explorer でも同じ問題が発生します。Chrome のみが完全に正常に動作します。 私はグーグルでよく検索しましたが、問題の根本は window.location.reload() 関数です。
関数を settimeout でラップしようとしましたが (以下を参照)、うまくいきません。
私の基本コードは、https ://github.com/facebook/facebook-php-sdk/blob/master/examples/with_js_sdk.php からわずかに変更された Facebook の例です。
--->> どうして Facebook の人たちが Firefox や IE で正しく動作しないコードをアップロードするのか不思議に思います。
私の使用コードは次のとおりです。
<?php
include_once($_SERVER['DOCUMENT_ROOT']."/config/config.php");
include_once($_SERVER['DOCUMENT_ROOT']."/config/facebook_config.php");
include($_SERVER['DOCUMENT_ROOT']."/config/connection.php");
// See if there is a user from a cookie
$user = $facebook->getUser();
if ($user) {
try {
// Proceed knowing you have a logged in user who's authenticated.
$user_profile = $facebook->api('/me');
} catch (FacebookApiException $e) {
echo '<pre>'.htmlspecialchars(print_r($e, true)).'</pre>';
$user = null;
}
}
?>
<!DOCTYPE html>
<html xmlns:fb="http://www.facebook.com/2008/fbml">
<body>
<?php if ($user) { ?>
Your user profile is
<pre>
<?php print htmlspecialchars(print_r($user_profile, true)) ?>
</pre>
<?php } else { ?>
<fb:login-button></fb:login-button>
<?php } ?>
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId: '<?php echo $facebook->getAppID() ?>',
cookie: true,
xfbml: true,
oauth: true
});
FB.Event.subscribe('auth.login', function(response) {
setTimeout('window.location.reload()',0);
});
FB.Event.subscribe('auth.logout', function(response) {
setTimeout('window.location.reload()',0);
});
};
(function() {
var e = document.createElement('script'); e.async = true;
e.src = document.location.protocol +
'//connect.facebook.net/en_US/all.js';
document.getElementById('fb-root').appendChild(e);
}());
</script>
</body>
</html>
Firefox と Internet Explorer でまだ「リロード」の問題が発生する