2
public function authorizationToken(){
$link = "https://api.ebay.com/identity/v1/oauth2/token";
$codeAuth = base64_encode($this->clientID.':'.$this->certID);
$ch = curl_init($link);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded','Authorization: Basic '.$codeAuth));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, "grant_type=authorization_code&code=".urlencode($this->authCode)."&redirect_uri=".$this->ruName."&scope=".urlencode('https://api.ebay.com/oauth/api_scope'));
$response = curl_exec($ch);
$json = json_decode($response, true);$info = curl_getinfo($ch);
curl_close($ch);print_r($json);}
4

2 回答 2

1

看起来您对refresh_token感到困惑authorization_token,因为您在两个不同的请求之间混合了不兼容的参数。

如果您尝试获取初始的“AccessToken”(AKA UserAccessToken、access_token、AuthToken、...),那么您不应请求正文中包含该scope参数。因此,您的请求正文应如下所示:

grant_type=authorization_code&redirect_uri=<redirect_uri>&code=<authorization_code>

从这里<authorization_code>返回的值在哪里。

有关差异的概述,我建议在有关该主题的官方文档上使用此答案。

于 2020-01-05T03:38:54.780 回答
0

试试这个代码

  public function authorizationToken(){
    $link = "https://api.ebay.com/identity/v1/oauth2/token";
    $codeAuth = base64_encode($this->clientID.':'.$this->certID);
    $ch = curl_init($link);
    curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded','Authorization: Basic '.$codeAuth));
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_POSTFIELDS, "grant_type=client_credentials&scope=".urlencode('https://api.ebay.com/oauth/api_scope'));
    $response = curl_exec($ch);
    $json = json_decode($response, true);
    $info = curl_getinfo($ch);
    curl_close($ch);
    print_r($json);
}
于 2020-01-01T07:32:18.850 回答