R Binance API HMAC SHA256 签名消息

Posted

技术标签:

【中文标题】R Binance API HMAC SHA256 签名消息【英文标题】:R Binance API HMAC SHA256 signed message 【发布时间】:2018-07-05 11:25:16 【问题描述】:

我尝试使用 binance API 发送已签名的 api 消息,但由于 404 错误而一直失败。有人可以帮我看看下面的代码吗?

library(jsonlite)
library(httr)
library(dplyr)
library(digest)


timestamp <- 1516941586 #as.numeric(as.POSIXct(Sys.time()))

post_message <- paste0(timestamp, 'public.api' ) # data_client.id = client 
id # data_key = key

sha.message <- toupper(digest::hmac('private.api', object = post_message, 
algo = 'sha256', serialize = F))

url <- 'https://api.binance.com/api/v3/account'

body = list('timestamp' = timestamp, 'signature' = sha.message)
body2 <- paste("?timestamp=",timestamp,"&signature=",sha.message, sep = "")


httr::POST(url, body2 = body, verbose())

这里是文档https://github.com/binance-exchange/binance-official-api-docs/blob/master/rest-api.md

【问题讨论】:

【参考方案1】:

根据网站中“POST /api/v1/order 的签名端点示例”部分下的示例,您可以遵循类似的内容。您需要用自己的 apiKey 和 secretKey 替换。

library(httr)
library(openssl)

url <- 'https://api.binance.com/api/v3/account'
apiKey <- "vmPUZE6mv9SD5VNHk4HlWFsOr6aKE2zvsw0MuIgwCIPy6utIco14y7Ju91duEh8A"
secretKey <- "NhqPtmdSJYdKjVHjA7PZj4Mge3R5YNiP1e3UZjInClVN65XAbvqqM6A7H5fATj0j"

timestamp <- 1516941586
recvWindow <- 1e20
postmsg <- paste0("timestamp=", timestamp, "&recvWindow=", recvWindow)
signature <- openssl::sha256(postmsg, key=secretKey)

GET(url, 
    add_headers("X-MBX-APIKEY"=apiKey),
    query=list(timestamp=timestamp, recvWindow=recvWindow, signature=signature), 
    verbose())

【讨论】:

这似乎是朝着正确方向迈出的一步!但我收到此错误:此请求的时间戳在 recvWindow 之外......所以我添加了 query=list(recvWindow = '100000000000000000', timestamp=timestamp, signature=signature) 然后我收到此错误:为此签名请求无效。 哦,apiKey 和 secretKey 是否正确?您需要将 recvWindow 添加到 postmsg 他们是正确的。像这样的 postmsg 吗? postmsg 没关系,我让它工作了!我只需要为服务器时间编写另一个获取。非常感谢! 我在运行代码时得到 401 Unauthorized。我认为 apiKey 和 secretKey 不是实时密钥

以上是关于R Binance API HMAC SHA256 签名消息的主要内容,如果未能解决你的问题,请参考以下文章

如何在 python 代码中使用 SHA256-HMAC?

如何在 python 代码中使用 SHA256-HMAC?

javascript中的HMAC SHA256十六进制摘要

在 php 中使用 SHA256 hmac 生成散列消息(key & msg 是假的)

hmac sha256和sha256的区别

hmac-sha256 2021-11-02