【发布时间】:2019-07-18 06:45:49
【问题描述】:
我需要使用 JWT 使用 API,为此,我使用 Guzzle 和 Firebase PHP-JWT 从 PHP 构建 API 客户端
API 的文档说:准备并发布 JWT 以进行授权。
端点网址:
https://api.example.com/auth
JWT 包含三个组件,标头、有效负载和签名。
Header: { "alg": "HS256", "typ": "JWT" }
Payload: { "clientId": "YOUR_CLIENT_ID","requestTime": "Y-m-d H:i:s" } (requestTime in GMT)
Signature: HMACSHA256( base64UrlEncode(header) + "." + base64UrlEncode(payload), YOUR_CLIENT_SECRET )
获取token的代码如下:
<?php
use \Firebase\JWT\JWT;
class Client
{
...
private function getAuthToken()
{
$requestTime = date('Y-m-d H:i:s T', time());
$payload = [
'clientId' => 'A1b2C3d4E5',
'requestTime' => $requestTime
];
$key = '9z8Y7x6w5V4';
$alg = 'HS256';
$token = JWT::encode($payload, $key, $alg);
$client = new \GuzzleHttp\Client;
$headers = ['content_type' => 'application/x-www-form-urlencoded'];
$response = $client->request('POST', 'https://api.example.com/auth', $headers, $token);
$body = $response->getBody();
$data = \json_decode($body->getContents());
}
...
}
如果打印 $data 我得到
stdClass Object
(
[success] => false
[data] => Wrong number of segments
)
我的问题: 我不知道为什么会出现此错误,以及我是否以某种不正确的方式发送请求。
我是使用 JWT 使用 API 资源的新手,我想我正在构建错误的方法。我有一些静态方式的值仅用于测试目的。
【问题讨论】: