我有以下代码:
$fb = new Facebook([
'app_id' => $appId,
'app_secret' => $appSecret,
'default_graph_version' => 'v2.9',
]);
$oAuth2Client = $fb->getOAuth2Client();
$tokenMetaData = $oAuth2Client->debugToken($accessToken);
dump($tokenMetaData);
$graphUser = $fb->get('/me?fields=first_name,last_name,email', $accessToken)->getGraphUser()->asArray();
dump($graphUser);
以上输出如下:
$元数据:
[
"app_id" => "..."
"application" => "My App Name"
"expires_at" => "2017-07-01 11:40:09.000000"
"is_valid" => true
"issued_at" => "2017-05-02 11:40:09.000000"
"metadata" => array:2 [
"auth_type" => "rerequest"
"sso" => "ios"
]
"scopes" => array:2 [
0 => "email"
1 => "public_profile"
]
"user_id" => "102..."
]
}
$ graphUser:
array:3 [
"first_name" => "John"
"last_name" => "Smith"
"id" => "102...",
]
正如你所看到的,scopes
中的$metaData
显然有email
所以它不是一个许可问题。尽管如此,图表用户有时没有电子邮件(尽管在某些情况下它确实如此)。
为什么这样,我该如何解决这个问题?
将您需要的字段添加到请求的URL中:
https://graph.facebook.com/me?fields=email,name
首先检查您的访问令牌是否获得用户对电子邮件的许可
https://graph.facebook.com/me/permissions?
access_token=(access-token)
&debug=all
如果在答案中,此内容不会出现:
{
"data": [
{
"permission": "email",
"status": "granted"
},
{
"permission": "public_profile",
"status": "granted"
}
]
}
也许在获取您的访问令牌时,我不会请求邮件所有权:将scope = email添加到请求中
https://www.facebook.com/v2.10/dialog/oauth?
client_id=(app-id)
&redirect_uri=(redirect-uri)
&scope=email
我通过指定图形api版本解决了这个问题。
我要求的字段first_name,last_name,email,picture
要url:https://graph.facebook.com/me
没有回复电子邮件。
要url:https://graph.facebook.com/v2.9/me
回复邮件了。
希望这可以帮助。
你必须检查这些步骤。
app.get(
'/auth/facebook',
passport.authenticate('facebook', {
scope: ['user_location', 'email', 'user_friends']
})
);
要么
FB.login(function(response) {
// your ajax script
},{
scope: 'email',
return_scopes: true
});
我今天遇到的一种可能性是,如果我正在注册我未使用我的email ID
登录的帐户,可能正在使用mobile number
到login
,甚至在我的个人资料中primary email
未设置或设置为mobile number
,在这种情况下facebook
为email
返回null。
我更新了帐户,并在primary email
的settings
下添加了facebook page
字段的电子邮件,然后我就能从email id
获得facebook
。
希望这有助于某人。
快乐的编码......