需要幫助....我需要從URL調用API調用JSON數據。它說,所謂的需求..PHP curl hash_hmac
- 內容類型:應用程序/ x-WWW窗體-urlencoded
- HTTP標頭:關鍵---> APIKEY
- HTTP標頭:SIG的---> HMAC POST數據的-sha1簽名與密鑰
- 之後的參數:時間戳---->當前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!」}。 任何線索?
{「error」:「無效簽名!」} –
您shpuld更改'curl_setopt($ ch,CURLOPT_POSTFIELDS,「timestamp =」。time());''到'curl_setopt($ ch,CURLOPT_POSTFIELDS,「timestamp =」。$ timestamp);'以便發佈您在簽名中使用的相同值。 – ojovirtual
事實上,你的簽名是錯誤的,你定義'$ secret_key',但使用'$ secret'來散列。 '$ signature = hash_hmac('sha1',$ timestamp,$ secret_key);' – ojovirtual