HitBTCのRestfull APIからPython 3で注文するプログラムを作成しています。
正しく実装されていると思いますが、エラーが返されます。
エラーは403間違った署名です。
ドキュメントの署名の定義は、連結されたuriとpostDataのhmac-sha 512の小文字の16進表現です。
HitBTC文書 - >https://hitbtc.com/api#tradingrestful
下記のプログラムの間違いを教えてください。python3 HitBTC Restfull API
API_KEY = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
SECRET_KEY = 'YYYYYYYYYYYYYYYYYYYYYYYYYYYYYY'
BASE_URL = 'http://demo-api.hitbtc.com'
nonce = str(int(time.mktime(datetime.datetime.now().timetuple()) * 1000 + datetime.datetime.now().microsecond/1000))
req = {
'clientOrderId': "".join(random.choice(string.digits + string.ascii_lowercase)for _ in range(30)),
'symbol': 'BTCUSD',
'side': 'buy',
'price': '3',
'quantity': '100',
'type': 'limit'
}
postdata = urllib.parse.urlencode(req)
url_path = '/api/1/trading/new_order?apikey=' + API_KEY + '&nonce=' + nonce
signature = hmac.new(SECRET_KEY.encode(), (url_path + postdata).encode(), hashlib.sha512).hexdigest()
reuslt = requests.post(BASE_URL + url_path, params=postdata, headers={'X-Signature': signature})
print(reuslt.json())
あなたはurlquotedデータをハッシングし、JSONを送信しています。この方法では、ハッシュは一致しません。 –
私はコメントを見ました。どうもありがとうございました。私はそれを修正したが、うまくいかなかった。 –