0

我无法找到正确的 access_tokens。我已经尝试了在 Google 和 developers.fb 上找到的所有方法,但是对于这个应用程序(我以前做过,并使它适用于另一个应用程序)我似乎并不成功。

我知道 FB 一直在更新他们的 API,所以也许我只是找到了过时的解决方案。

似乎有不同类型的访问令牌:用户访问令牌和页面访问令牌。我在 facebook 文档中找到了一些答案,但没有一个是我理解的。

我正在尝试创建的应用程序类似于生日提醒,因此它需要能够发送离线消息(fex。由 cron-job 运行,并仅发布到我拥有的一个 fb 页面,只是以应用程序本身的名义)

我已在此地址上的页面选项卡上注册了该应用程序:--https://www.facebook.com/dialog/pagetab?app_id=MY_APP'S_ID&display=popup&next=MY_URL现在可以从 Facebook 页面的设置中找到它。

然后我到达需要访问令牌的部分。我不知道哪个 URL 给了我什么样的访问令牌,所以我都尝试了:

我访问过这个 URL:(我写了所有重复的链接,教程中的答案,以及我重写的链接)(当然,出于安全原因,所有指向我的应用程序和网页的代码都被替换了)

-- https://www.facebook.com/dialog/oauth?client_id=0123456789011121&redirect_uri=http://www.example.com&scope=read_stream,publish_stream,offline_access--

-- https://www.facebook.com/dialog/oauth?client_id=MY_APP_ID&redirect_uri=MY_REDIRECT_URL&scope=read_stream,publish_stream,offline_access--

并得到:

http://www.example.com/?code=XXXXX1x1X1xxXxxX1xXxXxX1X111xX11XXXXX1XXXXXxX_XxXxxXxX1xxxXx1xXxXx-x1XxXXXxXXx1xXxXXXxXl1xX-111xXxxxXxxx1xXxxx1xXx1X1X1Xx-xxxXXXxXXXX1XXXXxx1Xxx1_xXxXxxxXx1x1XxXxxXx1XXxX-x1x1xxxXXxXxX1XX1XX1x1-xxXxxxx1Xx1XxXXXxxX#_=_

换句话说(我相信),检索了代码:

XXXXX1x1X1xxXxxX1xXxXxX1X111xX11XXXXX1XXXXXxX_XxXxxXxX1xxxXx1xXxXx-x1XxXXXxXXx1xXxXXXxXl1xX-111xXxxxXxxx1xXxxx1xXx1X1X1Xx-xxxXXXxXXXX1XXXXxx1Xxx1_xXxXxxxXx1x1XxXxxXx1XXxX-x1x1xxxXXxXxX1XX1XX1x1-xxXxxxx1Xx1XxXXXxxX#_=_

正如我在谷歌上发现的那样,我似乎还需要获取另一个代码,所以我访问了这个 URL(当然我已经尝试了我首先得到的第一个代码):

https://graph.facebook.com/oauth/access_token?client_id=0123456789011121&redirect_uri=http://www.example.com&client_secret=1x1111xx11111xXXx11x111111111x11&code=XXXXX1x1X1xxXxxX1xXxXxX1X111xX11XXXXX1XXXXXxX_XxXxxXxX1xxxXx1xXxXx-x1XxXXXxXXx1xXxXXXxXl1xX-111xXxxxXxxx1xXxxx1xXx1X1X1Xx-xxxXXXxXXXX1XXXXxx1Xxx1_xXxXxxxXx1x1XxXxxXx1XXxX-x1x1xxxXXxXxX1XX1XX1x1-xxXxxxx1Xx1XxXXXxxX#_=_

-- https://graph.facebook.com/oauth/access_token?client_id=MY_APP_ID&redirect_uri=MY_REDIRECT_URL&client_secret=MY_APP_SECRET&code=THE_CODE_I_GOT_FROM_THE_PREVIOUS_RUN--

但是当我尝试运行该应用程序时,我收到此错误消息:结果:{"error":{"message":"Malformed access token XXXXX1x1X1xxXxxX1xXxXxX1X111xX11XXXXX1XXXXXxX_XxXxxXxX1xxxXx1xXxXx-x1XxXXXxXXx1xXxXXXxXl1xX-111xXxxxXxxx1xXxxx1xXx1X1X1Xx-xxxXXXxXXXX1XXXXxx1Xxx1_xXxXxxxXx1x1XxXxxXx1XXxX-x1x1xxxXXxXxX1XX1XX1x1-xxXxxxx1Xx1XxXXXxxX#_=_","type":"OAuthException","code":190}}

我尝试过使用不同类型的访问令牌结尾(# =),因为我无法从上周检索到的另一个工作访问令牌到我构建的完全正常工作的应用程序中识别它。我记得那个没有那个结局。

如果有任何兴趣,我也会在此处发布脚本。我在教程中找到了它,它是非常简单的代码:

<?php
    // CURL function to send with post method
    function send_post_curl($url, $postdata = “”) {
    $ch = curl_init($url);
    curl_setopt ($ch, CURLOPT_POST, 1);
    curl_setopt ($ch, CURLOPT_POSTFIELDS, $postdata);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
    $data = curl_exec ($ch);
    curl_close ($ch);
    return $data;
    }
    // setup the message
    $fburl = 'https://graph.facebook.com/THE_FB_PAGE_ID/feed';
    $fbtoken = 'THE_ACCESS_TOKEN';
    $fbmsg = 'Great API to auto status, this is the message.
    Thank to WebDDR
    http://webddr.net/tips-and-tricks/facebook-offline-access-step-by-step-explanation/';
    $fbpcurl = 'access_token='. $fbtoken;
    $fbpcurl .= '&message='. str_replace('&', 'and', urlencode($fbmsg)) ;
    $result = send_post_curl($fburl, $fbpcurl);
    echo 'Result: '. $result;
?> 

我真的希望有人能帮助我,我这样做是为了在大学里接受教育。/约翰 PS。对不起,不得不与链接争吵,--link--因为论坛认为它是垃圾邮件Ds。

4

1 回答 1

0

试试这个代码:

<?php
session_start();   
$facebook_appid         = "facebook_appid";                                 // Facebook appplication id
$facebook_secret        = "facebook_secret";                // Facebook secret id
$redirect_uri           = "https://localhost/facebook_page/events.php";   // return url to our application after facebook login ## should be SAME as in facebook application
$scope                  = "user_photos,email,user_birthday,user_online_presence,offline_access,manage_pages,publish_stream,user_events,friends_events"; // User permission for facebook

$code                   = $_REQUEST["code"]?$_REQUEST["code"]:"";

if(empty($code)) {
    $_SESSION['state']  = time(); // CSRF protection
    $dialog_url         = "https://www.facebook.com/dialog/oauth?client_id=". $facebook_appid . "&redirect_uri=" . urlencode($redirect_uri) . "&state=". $_SESSION['state'] . "&scope=".$scope;
    header("location:".$dialog_url);
}

if($_SESSION['state'] && ($_SESSION['state'] == $_REQUEST['state'])) {
    $token_url          = "https://graph.facebook.com/oauth/access_token?". "client_id=" . $facebook_appid . "&redirect_uri=" . urlencode($redirect_uri). "&client_secret=" . $facebook_secret . "&code=" . $code;
    $response           = @file_get_contents($token_url);

    $params             = null;
    parse_str($response, $params);


    echo $params['access_token'];
    echo "<br>";

    //$offer_url        = "https://graph.facebook.com/".$dt->id."/conversations?access_token=".$dt->access_token;
    //$off              = @file_get_contents($offer_url);
    //$dto              = json_decode($off);

    //echo "<pre>";
    //print_r($dto);


}

?>
于 2013-01-25T09:54:30.047 回答