OAuth 响应作为 URL 工作,但无法让 cURL 在 PHP 中工作

OAuth response works as URL but can't get cURL to work in PHP

我正在尝试获得 OAuth 响应以使用 Slack,但我并不高兴。

我得到了从 Slack 返回的 "code" var 值,我需要将其包含在我的响应中。

我可以使用返回值手动构建 URL 并将其作为响应发送以完成 OAuth 并安装我的应用程序——每次都有效。它看起来像这样:

https://slack.com/api/oauth.access?client_id=12345&code=123.456.789&client_secret=12345678&

'code'var是变量位,其他都是静态的

我知道 PHP 正在获取我需要的 "code" 的值,因为我可以回应它。

这是不起作用的 PHP:

    <?php 

    $authCode = $_GET['code'];
    echo $authCode; //succeeds

    $client_id = '12345';
    $client_secret = '12345678';


    $data = array(
                'client_id' => $client_id,
                'client_secret' => $client_secret,
                'code' => $authCode
                    );
            $data_string = json_encode($data);


    $ch = curl_init('https://slack.com/api/oauth.access');

                curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
                curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
                curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                curl_setopt($ch, CURLOPT_HTTPHEADER, array(
                    'Content-Type: application/json',
                    'Content-Length: ' . strlen($data_string))
                );
            //Execute CURL

            $result = curl_exec($ch);
            return $result; 


     ?>

我希望在发送响应后看到加载的新页面,但首先要做的是。

这是我第一次尝试这样的事情,所以我怀疑我错过了一个重要的部分,我希望有人能帮助我分类。

欢迎任何能取得成功结果的替代方法。谢谢!

这里有两点不太对:

  1. 您正在以 JSON 格式提供输入参数,但是,根据 OAuth 2.0 规范,Slack API 要求参数以 GET 或 POST 此处记录的参数:https://api.slack.com/web#basics。所以你应该使用 http_build_query($data) 而不是 json_encode($data),并且不要自己设置任何 HTTP headers。

  2. 请求中缺少 redirect_uri 参数