私は HTML 5 を使用していくつかのものを開発し、同じ中に Facebook JavaScript SDK を挿入しています。
私がしたいFacebookアプリケーションを開発しました:
FB.LOGIN()
1) ユーザーが facebook にログインしていない場合、ログインを求められますが、ユーザーがログインしてアプリケーションを開くと、ユーザーがリンクを再度クリックする必要がなく、自動的に許可を求める必要があります。
スタック オーバーフローに関する質問が 1 つあります。Facebook アプリケーションがインストール後に必要なアクセス許可を自動的に要求するようにするにはどうすればよいですwindow.top.location = "<?php echo $loginUrl; ?>";
か?
JavaScript コード:
<div id="fb-root"></div>
<script>
// Load the SDK asynchronously
(function(d){
var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
ref.parentNode.insertBefore(js, ref);
}(document));
// Init the SDK upon load
window.fbAsyncInit = function() {
FB.init({
appId : 'appid', // App ID
channelUrl : '//www.domain.com/channel.html', // Channel file
status : true, // Check login status
cookie : true, // Enable cookies to allow the server to access the session
xfbml : true // Parse XFBML
});
FB.getLoginStatus(function(response) {
if (response.status === 'connected') {
var uid = response.authResponse.userID;
var accessToken = response.authResponse.accessToken;
document.getElementById('auth-loggedout').style.display = 'none';
document.getElementById('auth-loggedinnotauthenticate').style.display = 'none';
document.getElementById('loginauthenicated').style.display = 'block';
}
else
if (response.status === 'not_authorized') {
window.top.location = "https://www.facebook.com/dialog/oauth?client_id=id&redirect_uri=http://apps.facebook.com/appp/";
}
else {
window.top.location = "https://www.facebook.com/login.php?api_key=id&skip_api_login=1&display=page&cancel_url=http://apps.facebook.com/appp/";
}
});
</script>