Facebook访问令牌


Facebook Access Tokens

我正在尝试使用下面的代码获取Facebook访问令牌:我之前确实创建了自己的函数,但它返回了相同的错误,我无法弄清楚问题是什么。

function getAccessToken(){
        $app_id = FB_APP_ID;
        $app_secret = FB_SECRET_ID;
        $my_url = FB_PAGE_URL;
        $code = $_REQUEST["code"];   

        if(empty($code)) {
       $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
       $dialog_url = "https://www.facebook.com/dialog/oauth?client_id=" 
         . $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
         . $_SESSION['state'];
       echo("<script> top.location.href='" . $dialog_url . "'</script>");
     }      
    if($_REQUEST['state'] == $_SESSION['state']) {
       $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;
       parse_str($response, $params);
       $graph_url = "https://graph.facebook.com/me?access_token=" 
         . $params['access_token'];
       $user = json_decode(file_get_contents($graph_url));
       echo("Hello " . $user->name);
     }
     else {
       echo("The state does not match. You may be a victim of CSRF.");
     }
}

取自服务器端身份验证,但我不断收到此错误:

    Warning: file_get_contents(https://graph.facebook.com/oauth/access_token?
client_id=ID HERE&redirect_uri=URLHERE&cli
ent_secret=SECRECT&code=AQCI5rNgw9zCPHWGozeT59asg7_022u5tVc5XSef49BiX
IaF5_MAMqFwsqOAquUHgjOu_99ONwUV6IC7k-jV6DsWf9ni3jm8t59aHCBp1jrFaDthPbIKLNLQ-
fZgB5MLh1le5BAPKj_l57jhTLTBfOdxRU30mFCMYzMch8MYFpCmJ9GrjSSGwt0OKb_LNqMoRf8) [function.file-
get-contents]: failed to open stream: HTTP request failed! HTTP/1.0 400 Bad Request

有人知道解决方法吗?

这可能是 file_get_contents 方法的问题,因为您正在构造的 url 看起来不错。

如果你搜索"facebook file_get_contents failed to open stream"你会得到很多关于这个问题的结果,很多就在堆栈溢出上。
看起来file_get_contents在此线程中作为状态的HTTPS问题:[function.file-get-content]:无法打开流。

也许尝试其他一些发出 http 请求的方法?也许卷曲?
只是为了测试事情,请尝试从命令行使用curl,其中包含您使用php脚本尝试的相同url,看看您得到了什么。

查看请求响应,您尚未定义 Facebook 应用程序设置。

当您请求令牌时,您正在使用FB_APP_IDFB_SECRET_IDFB_PAGE_URL,但在响应中我可以看到它们分别定义为:"ID HERE","SECRECT"和"URLHERE"。

我已经设法使用 PHP SDK 解决了这个问题,经过与SDK的长期斗争,让它做我想做的事。

我也确实提出了另一个问题,有

同样的想法,但有另一个问题。这个问题现在已经解决了。

查看此问题以获取此问题的答案: Facebook 访问令牌服务器端身份验证