問題を再現することができず、テストするものが何もないため、これは私にとって非常にイライラする問題です. 何らかの理由で、Facebook アプリのランダムなユーザーの UID が 0 として返されます。私が知る限り、特定のブラウザーの問題ではないようです。
これが私のアプリの仕組みです。ユーザーがクリックして今すぐ入力できるホームページがあります。このボタンはoauth();
JS 関数をトリガーし、OAuth ログイン ウィンドウを開きます。以下の私のJSコードを参照してください..
window.fbAsyncInit = function() {
FB.init({
appId : 'xxxxxxxxxxxxx', // App ID
channelUrl : '//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.Canvas.scrollTo(0,0); //makes window scroll to top when loading page within iframe
FB.Canvas.setAutoGrow(); //resize the height of the iframe automatically
};
// 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));
function oauth() {
FB.login(function(response) {
if (response.authResponse) {
console.log('Welcome! Fetching your information.... ');
FB.api('/me', function(response) {
console.log('Good to see you, ' + response.name + '.');
//window.location.reload();
//alert("bing bong bing");
$.fancybox.open("#entry-form", {
width: 645,
minHeight: 920,
padding: 0,
scrolling: 'no',
wrapCSS: 'enternow-form',
type: 'iframe',
href: 'upload',
helpers : {
overlay : {
opacity: 0.95,
css : {
'background-color' : '#fff'
}
}
}
});
});
} else {
console.log('User cancelled login or did not fully authorize.');
}
});
}//end oauth function
oauth ログインが成功したら、フォームを含む FancyBox iframe を開きます。UIDを取得するためのiframeページのFacebook PHPコードは次のとおりです...
<?php header('P3P:CP="IDC DSP COR ADM DEVi TAIi PSA PSD IVAi IVDi CONi HIS OUR IND CNT"'); ?>
<?php session_start(); ?>
<?php require_once("../src/facebook.php"); ?>
<?php
$config = array();
$config["appId"] = 'xxxxxxxxxxxxxx';
$config["secret"] = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx';
$config["fileUpload"] = false; // optional
$facebook = new Facebook($config);
// get signed request to help determine if user is an admin
$signedRequest = $facebook->getSignedRequest();
// Get User ID
$user = $facebook->getUser();
// We may or may not have this data based on whether the user is logged in.
//
// If we have a $user id here, it means we know the user is logged into
// Facebook, but we don't know if the access token is valid. An access
// token is invalid if the user logged out of Facebook.
if ($user) {
try {
// Proceed knowing you have a logged in user who's authenticated.
$user_profile = $facebook->api('/me');
} catch (FacebookApiException $e) {
error_log($e);
$user = null;
}
}
// Login or logout url will be needed depending on current user state.
if ($user) {
$logoutUrl = $facebook->getLogoutUrl();
} else {
$loginUrl = $facebook->getLoginUrl();
}
?>
<?php echo $user //this is the user's ID ?>