Gimbal API身份验证失败,401未经授权(PHP cURL请求)

时间:2015-08-29 20:13:37

标签: php api authentication curl gimbal

我正在尝试与Gimbal管理器Restful API建立联系。我有一个帐户和我的组织的API KEY。我的cURL请求因API端点的401未经授权的响应而失败。这是我在PHP中的cURL请求:

!nullptr

(编辑),这里是请求标题(来自上面的$ headerSent var)

    // from Gimbal Manager:
    define('ORG_API_KEY', 'XXXXXXXXXXXXXXXXX') ;

    // new beacon registration object:
    $post = array (
        "factory_id" => "XXXX-XXXXX",
        "name" => "NewBeacon",
        "latitude" => 12345
        "longitude" => 67890,
        "visibility" => "public"
    );

    $url = "https://manager.gimbal.com/api/beacons";
    $headers = array(
          'AUTHORIZATION: Token token=' . ORG_API_KEY, 
          'Content-type: application/json'
    ) ;
    $debug = 1 ;
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    curl_setopt($ch, CURLOPT_HTTPHEADER, $headers, TRUE);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
    if ($debug) {
        curl_setopt($ch, CURLOPT_VERBOSE, TRUE);
        curl_setopt($ch, CURLOPT_HEADER, TRUE);
        curl_setopt($curl, CURLINFO_HEADER_OUT, true);
    }

    curl_setopt($crl, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($crl, CURLOPT_SSL_VERIFYPEER, false);

    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post);

    $result = curl_exec($ch);

以下是Gimbal的回复:

POST /api/beacons HTTP/1.1
Host: manager.gimbal.com
Accept: */*
Content-Length: 577
Expect: 100-continue
Content-Type: multipart/form-data; boundary=----------------------------ce1a4e9dd55e

我尝试了几种表达AUTH令牌的方法:

HTTP/1.1 401 Unauthorized
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Date: Sat, 29 Aug 2015 20:05:10 GMT
Server: Apache
Status: 401 Unauthorized
Vary: Accept-Encoding
WWW-Authenticate: Token realm="Application"
X-Content-Type-Options: nosniff
X-Frame-Options: SAMEORIGIN
X-Request-Id: 7abe53cd-d161-4886-bb61-8cfedf71743a
X-XSS-Protection: 1; mode=block
Content-Length: 27
Connection: keep-alive
HTTP Token: Access denied.

他们都给出了相同的401响应。我注意到这里和其他地方的其他门票描述了类似的问题,但没有一个被标记为已解决。

有没有人有幸与Gimbal Manager API联系?如果是这样,你的代码看起来有什么不同吗?

1 个答案:

答案 0 :(得分:0)

最后,我的初始代码出现了2个问题。

CURLOPT_HTTPHEADER上的TRUE标志阻止发送AUTH / Content-type标头(不知道为什么我在那里有它并且不确定该标志是否有任何值或含义)。

我发送的POST数据格式不正确。由于我在请求内容类型的JSON,因此期望POST数据采用该格式。一旦我添加了json_encode($ post),一切正常。

curl_setopt($ch, CURLOPT_HTTPHEADER, $headers, TRUE);
.. .became ....
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

and

curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
... became ....
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($post));

有时需要仔细输入并格式化一个大的StackOverflow问题才能看到代码中的缺陷并自行解决。 :)