Facebookのログインを自分のWebサイトのログインシステムと統合したいWebサイトに取り組んでいます。facebook-php-sdkをコードに統合しました。ログイン機能は正常に機能します。以下は私が問題にしている点です...
- ログアウトしてログインをクリックすると、Facebookのログイン画面が開きません。
- ログアウトしてページを更新すると、ログインの詳細が再び表示されます。そして、ログインボタンが消えます。
- 上記の2つのポイントが解決した場合、Webサイト全体でログインセッションを維持するにはどうすればよいですか?
上記の2つのポイントについては、以下のコードを使用しました。
require 'src/facebook.php';
$facebook = new Facebook(array(
'appId' => YOUR_APP_ID,
'secret' => SECRET_KEY,
));
session_start();
if($_REQUEST['msg'] == 'logout'){
setcookie('fbsr_'.$facebook->getAppId(), '', (time() - 3600), '/', 'domain.com');
$sts = $facebook->destroySession();
session_destroy();
header("Location: index.php");
//echo '<meta http-equiv="refresh" content="2;url=index.php">';
}
$userId = $facebook->getUser();
if ($userId && !isset($_SESSION['fbdata'])) {
$_SESSION['fbdata'] = array("userid" => $userId);
}
<?php if ($userId) {
$userInfo = $facebook->api('/' + $userId); ?>
Welcome <?= $userInfo['name'] ?>
<?php } else { ?>
<div id="fb-root"></div>
<fb:login-button></fb:login-button>
<?php } ?>
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.init({
appId : '<?= YOUR_APP_ID ?>',
status : true,
cookie : true,
xfbml : true,
oauth : true,
});
FB.Event.subscribe('auth.login', function(response) {
//window.location.reload();
});
};
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
</script>
<br />
<br />
<a href="<?php echo $_SERVER['PHP_SELF']."?msg=logout"; ?>">Logout</a>