Facebook检索正确的acess_tokens

时间:2013-01-25 09:20:49

标签: php facebook

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

我知道FB正在不断更新他们的API,所以也许我只是发现了过时的解决方案。

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

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

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

然后我到达需要访问令牌的部分。 我不知道哪个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#_=_

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

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。 对不起,不得不与链接争吵,因为论坛认为这是垃圾邮件 DS。

1 个答案:

答案 0 :(得分: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);


}

?>