1

コインベース API を送信してお金を受け取り、ゲームで使用しようとしていますが、以下のコードを実行してお金を送信すると無効な署名エラーが発生します。どこが間違っているのかわかりません。アカウントの詳細を取得しようとしましたが、正常に機能しており、アカウントの詳細を取得できます。

<?php
$API_VERSION = '2016-02-01';
$curl = curl_init();
$timestamp = json_decode(file_get_contents("https://api.coinbase.com/v2/time"), true)["data"]["epoch"];

$req = "/v2/accounts/:account_id/transactions";
$url = "https://api.coinbase.com".$req;
$cle = "xxxxxxx";
$secret = "xxxxxxxx";
$params=['type'=>'send', 'to'=>'xxxxxxxxxx', 'amount'=>0.0001, 'currency'=>'BTC'];

curl_setopt_array($curl, array(
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_URL => $url,
CURLOPT_POST => true,
CURLOPT_USERAGENT, 'local server',
CURLOPT_POSTFIELDS => json_encode($params),
CURLOPT_HTTPHEADER => array(
"CB-VERSION:" . $API_VERSION,
"CB-ACCESS-SIGN:" . hash_hmac('sha256', $timestamp."GET".$req, $secret),
"CB-ACCESS-KEY:" . $cle,
"CB-ACCESS-TIMESTAMP:" . $timestamp,
'Content-Type: application/json'
),
CURLOPT_SSL_VERIFYPEER => false
));

$rep = curl_exec($curl);
curl_close($curl);

print_r($rep);
?>
4

2 に答える 2

0

URL では、などの実際のアカウント ID$reqに置き換える必要があります。:account_id3c04e35e-8e5a-5ff1-9155-00675db4ac02

最も重要なことは、これは POST 要求であるため、OAuth 署名に署名にペイロード (POST データ) を含める必要があることです。

hash_hmac('sha256', $timestamp."POST".$req.json_encode($params), $secret),
于 2016-03-11T17:04:55.483 に答える
0

このエラーが発生したとき、それはアカウント ID であり、通貨アカウントごとに異なります。署名の何が問題なのかを突き止めるのに時間がかかりすぎました...とにかく、GETがうまくいったので試してみましたが、他のすべてのリクエストタイプは無効な署名エラーで終わりました。

于 2018-01-23T21:19:46.887 に答える