24

我正在尝试使用 Facebook Graph API 从 Facebook 获取相册并将它们放在我正在开发的网站上。我在 Codeigniter 框架中使用 PHP 作为我的语言,并重定向到 Facebook URL 以获取用户的访问令牌。Facebook 向我返回了一个访问令牌,我将其抓取并插入到我的数据库中。

话虽如此,当我尝试通过转到图形 URL 来获取相册的 JSON 数据时,它会返回一个错误。图 URL 和错误是:

https://graph.facebook.com/1298926000574/photos?access_token=[MY ACCESS TOKEN]

My access token: AQBxqdB64GHNTGY5Yp_IOuMY7NerwNtXVVrp2HwT1qXj02zqU-63KJDyB2jzqurlJ4M0vd7TAu7upA6T7ZYQzIChr2PgD1dpu-6Iebi0WVILbBSBOu-yj7sgcHSGS-Ew4Yio0I9In-1O5jOxbYLDMbI0Zmwk-F1-u-7a8iVvTJram8PvpmdRt5eg

Returned error:

{
"error": {
  "message": "Malformed access token [MY ACCESS TOKEN]",
  "type": "OAuthException",
  "code": 190
}
} 

我真的不确定为什么 Facebook 不断将这个错误返回给我。访问令牌很长,我将它作为“文本”字段存储在我的数据库中。我听从了他们的指示,现在他们正朝我的脚开枪。任何帮助将非常感激。

4

6 回答 6

67

我遇到了同样的问题,我发现这篇文章正在寻找解决方案。我注意到“我们的”访问令牌有很多奇怪的符号,而其他的只是一个字母数字字符串。

我相信您(和我)犯的错误是将代码access_token混合

在将 facebook 用户发送到您的 api 以确认访问后,他们将返回到您的网站,并带有$_GET['code']. 此代码需要通过 Facebook 验证,成功后将返回access_token

$app_id = [YOUR_APP_ID];
$app_secret = [YOUR_APP_SECRET];
$my_url = [THE_SAME_AS_THE_POST_BEFORE];
$code = $_GET['code'];

$token_url = "https://graph.facebook.com/oauth/access_token?"
. "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
. "&client_secret=" . $app_secret . "&code=" . $code;

$response = file_get_contents($token_url);
$params = null;
json_decode($response, $params);
$access_token = $params['access_token'];

有关使用 PHP 获取 access_token 的更多信息

有关使用正确的 redirect_uri 的更多信息

于 2012-06-22T09:41:15.043 回答
3

一个 wp 插件返回相同的错误,这是解决方案,它可能与您的问题有关:

php 请求 access_token,facebook 服务器返回它。

返回的包含 access_token USED 的消息类似于:

access_token=.......

但是对于新创建的应用程序(2012 年),facebook 服务器返回:

access_token=.....&expires=.....

如果您的代码解析错误,如

$access_token=str_replace('access_token=','',$message);

那么你的 $access_token 错误地包含了额外的 &expires 等。

它应该被解析为:

parse_str($message,$ar); $access_token=$ar['access_token'];
于 2012-12-29T15:43:54.347 回答
2

我有同样的问题。想通了它是如何工作的,这里适用于任何陷入同样泥泞的人。

require 'facebook-php-sdk/facebook.php';
$facebook = new Facebook(array(
  'appId'  => 'APP ID',
  'secret' => 'SECRET KEY',
));

// Get User ID
$user = $facebook->getUser();  
if ($user) {
    $accessToken = $facebook->getAccessToken();
        try {
            $url = "https://graph.facebook.com/1298926000574/photos?access_token=".$accessToken;

            $photos = $facebook->api($url);
            var_dump($photos);
        } catch (FacebookApiException $e) {
            $user = null;
        }
    }   
} else {
    //echo "You need to login";
    header("Location:".$facebook->getLoginUrl());
}
于 2012-10-23T05:00:51.237 回答
1

tl;博士

访问令牌应该由您的应用程序 ID 和您的访问令牌组成,|它们之间有一个竖线 ( ) 字符:123456789012345|AbCDefGHijKLMNOpqRSTUVwxYZ

创建和使用访问令牌

注意:在本教程中,我只使用虚拟凭据。它们的风格与真实的风格相同,但它们的确切值只是一系列递增的数字或字符。切勿在线发布您的实际凭据!

创建访问令牌

要求:

  • 应用编号:123456789012345
  • 应用秘籍:ZYxwVUTSRqpONMLKjiHGfeDCbA

如果您按照访问令牌创建指南进行操作,您将找到可以创建的 URL:

GET /oauth/access_token?client_id={app-id}&client_secret={app-secret}&grant_type=client_credentials

如果我们在我们的虚拟凭证中插入 GET 请求的 URI 应该如下所示:

 http://graph.facebook.com/oauth/access_token?client_id=123456789012345&client_secret=ZYxwVUTSRqpONMLKjiHGfeDCbA&grant_type=client_credentials

响应将是:

{
  "access_token": "123456789012345|AbCDefGHijKLMNOpqRSTUVwxYZ",
  "token_type": "bearer"
}

访问令牌包含您的应用程序 ID,后跟一个管道 ( |),然后是可以称为实际访问令牌的字符串。

使用访问令牌

要求:

  • 访问令牌:123456789012345|AbCDefGHijKLMNOpqRSTUVwxYZ
  • 无论您需要什么其他凭证。本例中的用户 ID:1234567890

在这个例子中,我将按照官方 facebook 指南发送通知。他们展示了这个模板:

POST /{recipient_userid}/notifications?access_token=... &template=...&href=...

这意味着,在您填写凭据后,示例 POST 请求应如下所示:

http://graph.facebook.com/1234567890/notifications?access_token=123456789012345|AbCDefGHijKLMNOpqRSTUVwxYZ&template=Test&ref=notif_test
于 2018-02-16T17:22:26.840 回答
1

您正在发送code而不是access_token在您的请求中。

Laravel Socialite用户的解决方案:

利用:

$response = Socialite::driver($provider)->getAccessTokenResponse($request['code']);
$user = Socialite::driver($provider)->userFromToken($response['access_token']);

代替:

$user = Socialite::driver($provider)->user();
于 2016-10-17T14:49:45.387 回答
-1

正如错误所说,它是格式错误的异常意味着格式化request.

https://graph.facebook.com/me/photos/?access_token=[your_accesstoken]

所以它会像

https://graph.facebook.com/me/photos/?access_token=AQBxqdB64GHNTGY5Yp_IOuMY7NerwNtXVVrp2HwT1qXj02zqU-63KJDyB2jzqurlJ4M0vd7TAu7upA6T7ZYQzIChr2PgD1dpu-6Iebi0WVILbBSBOu-yj7sgcHSGS-Ew4Yio0I9In-1O5jOxbYLDMbI0Zmwk-F1-u-7a8iVvTJram8PvpmdRt5eg
于 2013-02-27T19:43:36.937 回答