Нужна помощь в этом... Мне нужно получить данные json из вызова API с URL-адреса. Он сказал, что вызванные потребности ..
- Content-Type: application/x-www-form-urlencoded
- ЗАГОЛОВКИ HTTP: ключ ---> APIKEY
- ЗАГОЛОВКИ HTTP: sig ---> Подпись HMAC-SHA1 данных POST с секретным ключом
- POST PARAMETER: timestamp ----> Текущая временная метка Unix
Это мой код...
$key = 'APIKEY';
$secret = 'APISECRET';
$timestamp = time();
$signature = hash_hmac('sha1', $timestamp, $secret);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://www.domain.com/getticker");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($ch, CURLOPT_HEADER, FALSE);
curl_setopt($ch, CURLOPT_POST, TRUE);
curl_setopt($ch, CURLOPT_POSTFIELDS, "timestamp=".time());
curl_setopt($ch, CURLOPT_HTTPHEADER, array("Content-Type: application/x-www-form-urlencoded","key: ".$key,"sig: ".$signature));
$response = curl_exec($ch);
curl_close($ch);
echo $response;
Это дало мне сообщение об ошибке {"error":"Invalid Signature!"}. Любые подсказки?
curl_setopt($ch, CURLOPT_POSTFIELDS, "timestamp=".time());
наcurl_setopt($ch, CURLOPT_POSTFIELDS, "timestamp=".$timestamp);
, чтобы опубликовать то же значение, которое вы используете в подписи. - person ojovirtual   schedule 12.03.2014$secret_key
, но используете$secret
для хеширования.$signature = hash_hmac('sha1', $timestamp, $secret_key);
- person ojovirtual   schedule 12.03.2014