我正在尝试在 Bitmex 上进行 POST 操作,以 4009.9 的价格购买 1 份名为 XBTUSD(比特币/美元)的合约,到期时间1545674400(UNIX 时间戳,几个小时后),我们需要进行身份验证。这看起来很简单。
我们正在使用API,我们正在用R编写(api-secret是假的抱歉!!)
我们需要在签名中使用 hmac 转换我们的请求,使其成为以 16 为基数的数字。
我们尝试定义我们的签名
signature=hmac("Kjxd5H5sPnBq6oXmnKrQAbKPIAXuKsInHRmD9CF2Dh3-4I6j", 'POST/api/v1/order1545674400{"symbol":"XBTUSD","price":4009.0,"orderQty":1}', algo = "sha256")
然后开机自检
POST("https://www.bitmex.com/api/v1/order",body = 'POST/api/v1/order1545674400{"symbol":"XBTUSD","price":4009.0,"orderQty":1}',add_headers("api-key":"R1IdBlJD0-fCXypR2TTQVCF6", "api-signature":signature))
或类似的东西,我们得到
403 或 401
我不明白出了什么问题。我可以发出不需要身份验证的请求,但不能提出需要身份验证的请求!
谢谢!
乍一看,您似乎忘记了标头中的"api-expires"参数。对我有用的方法是,该正文是一个命名列表(如果您使用的是 httr 包),在"POST"函数调用中带有附加参数:编码 = 'json'。
如果要更详细地了解错误的含义,请执行以下操作:
味精 = 发布(....)rawToChar(msg$content)