Coincheck(コインチェック) API が上手くいきません。
Coincheck(コインチェック)の公式サイトの API 概要に、
(コインチェックAPIドキュメント)
https://coincheck.com/ja/documents/exchange/api
ーーーーーーーーーーーーーーーーーーーーー
認証が必要なリクエストでは、以下の情報を HTTP Header に含めてリクエストする必要があります。
ACCESS-KEY APIキー で作成したアクセスキー
ACCESS-NONCE 毎リクエストごとに増加する必要のある正の整数。通常はUNIXタイムスタンプを用います。最大値は 9223372036854775807 です。APIキーごとに管理されます。
**ACCESS-SIGNATURE **後述するSIGNATURE
SIGNATUREの作成
SIGNATUREは、ACCESS-NONCE, リクエスト先URL, リクエストのボディ を全て文字列にし連結したものを、HMAC-SHA256 hash形式でシークレットキーを使って署名した結果です。
SIGNATUREの作成に関しては、サンプルコードの API_SECRET などの部分を変更しています。
php
1$strUrl = "https://coincheck.com/api/accounts/balance"; 2$intNonce = time(); 3$arrQuery = array("hoge" => "foo"); 4$strAccessSecret = "API_SECRET"; 5$strMessage = $intNonce . $strUrl . http_build_query($arrQuery); 6$strSignature = hash_hmac("sha256", $strMessage, $strAccessSecret); 7# => "3bc1f33d802056c61ba8c8108f6ffb7527bcd184461a3ea0fed3cee0a22ae15d"
上記を踏まえて
新規注文API
php
1function new_order($ACCESS_KEY, $url,$API_SECRET){ 2 3 //アクセスキーの取得 4 $strAccessKey = $ACCESS_KEY; 5 //シークレットキーの取得 6 $strAccessSecret = $API_SECRET; 7 //リクエスト先のurl取得 8 $strUrl = $url; 9 //タイムスタンプの取得 10 $intNonce = time(); 11 12 $request_body = array( 13 "rate" => "28500", 14 "amount" => "0.005", 15 "order_type" => "buy", 16 "pair" => "btc_jpy" 17 18 ); 19 //**SIGNATUR**Eの作成 20 $strMessage = $intNonce . $strUrl . '?' . http_build_query($request_body ); 21 $strSignature = hash_hmac("sha256", $strMessage, $strAccessSecret); 22 23 //認証時ヘッダー 24 $headers = array( 25 "ACCESS-KEY: {$strAccessKey}", 26 "ACCESS-SIGNATURE: {$strSignature}", 27 "ACCESS-NONCE: {$intNonce}", 28 ); 29 30 $curl = curl_init(); 31 32 curl_setopt($curl, CURLOPT_URL, $strUrl ); 33 curl_setopt($curl, CURLOPT_CUSTOMREQUEST, 'POST'); 34 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); 35 curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); 36 //ヘッダー追加オプション 37 curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); 38 $response = curl_exec($curl); 39 40 $result = json_decode($response, true); 41 curl_close($curl); 42 return $result; 43} 44 45 46 47//新規注文url 48$new_order_url = "https://coincheck.com/api/exchange/orders"; 49 50//レスポンスの結果を取得 51//引数のキーは、値を入れております 52$new_order_result = new_order($strAccessKey,$new_order_url ,$strAccessSecret); 53 54 55//array(2) { ["success"]=> bool(false) ["error"]=> string(22) "invalid authentication" } 56var_dump($new_order_result); 57exit();
var_dump($new_order_result);で無効な認証となってしまいます。
他のAPIは、publicAPI, privateAPI(認証なども)は、上手く取得できます。
他の上手くいっているリクエストは、GETメソッドなのですが、今回(新規注文API)はPOSTメソッドで、何かそこの違いで、上手くいっていないなどあるのでしょうか?
新規注文APIのところだけ、なかなか上手くいかず、原因が分からなかったので、アドバイスなど頂けると幸いです。
//追記部分
post, getの違いが原因だと思っていたのですが、
parameter を 送ったときに、無効な認証となってしまいます。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/06/22 05:41