Проверка подлинности PHP для частного API Coinbase Exchange

Я пытаюсь пройти аутентификацию в частном API Coinbase Exchange, чтобы получить баланс и разместить / отменить заказ. Ниже приведена демонстрационная версия кода, который я пытаюсь использовать. Я следовал за документами, но продолжаю получать следующую ошибку:

{"message":"invalid signature"}

Может кто-нибудь сказать, пожалуйста, что я делаю не так? 🙂

РЕДАКТИРОВАТЬ: я изменил приведенный ниже код на основе ответа Sašo, так что теперь он работает.

<?php
$key = "";
$secret = "";
$passphrase = "";

$time = time();
$url = "https://api.gdax.com/accounts";

$data = $time."GET"."/accounts";
echo $data . "<br/>";

$sign = base64_encode(hash_hmac("sha256", $data, base64_decode($secret), true));
echo $sign . "<br/>";

$headers = array(
'CB-ACCESS-KEY: '.$key,
'CB-ACCESS-SIGN: '.$sign,
'CB-ACCESS-TIMESTAMP: '.$time,
'CB-ACCESS-PASSPHRASE: '.$passphrase,
'Content-Type: application/json'
);

var_dump($headers);

echo $url;

static $ch = null;

if (is_null($ch)) {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2228.0 Safari/537.36');
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);

$res = curl_exec($ch);
echo $res;
}

4

Решение

Вы пропускаете истинный параметр для raw_output при выполнении hash_hmac

http://php.net/manual/en/function.hash-hmac.php

raw_output: при значении TRUE выдает необработанные двоичные данные. FALSE выводит строчные буквы

2

Другие решения

Может быть что-то глупо. дважды проверьте ваш ключ, пароль и секрет. Также проверьте разрешения, которые вы включили при создании ключа.

0

Сашо Матейина прав. Вы, вероятно, должны лучше пользовательский сервер пользовательский агент тоже.

$userAgent=$_SERVER['HTTP_USER_AGENT'];
curl_setopt($ch, CURLOPT_USERAGENT, $userAgent);
0