Coinbase.com无效签名

时间:2017-01-23 15:10:26

标签: bash curl go signature coinbase-api

我搜索了其他帖子,因为我不是唯一有签名问题的人。我尝试了几种语言并且我总是遇到同样的问题。

使用coinbase.com进行API身份验证时我做错了什么:

# normally I fetch the timestamp from https://api.coinbase.com/v2/time
TIMESTAMP=$(date +%s)
SIG=$(echo -n "${TIMESTAMP}GET/v2/accounts" | hmac256 --stdkey $COINBASE_SECRET)

curl https://api.coinbase.com/v2/accounts \
  --header "CB-ACCESS-KEY: $COINBASE_KEY" \
  --header "CB-ACCESS-SIGN: $SIG" \
  --header "CB-ACCESS-TIMESTAMP: $TIMESTAMP" \
  --header "CB-VERSION: 2016-03-08"

我想去做一些事情:

nonce := strconv.FormatInt(int64(time.Data.Epoch), 10)
message := nonce + req.Method + endpoint // endpoint "/v2/accounts"
req.Header.Set("CB-ACCESS-KEY", a.Key)
h := hmac.New(sha256.New, []byte(a.Secret))
h.Write([]byte(message))

signature := hex.EncodeToString(h.Sum(nil))

req.Header.Set("CB-ACCESS-SIGN", signature)
req.Header.Set("CB-ACCESS-TIMESTAMP", nonce)
req.Header.Set("CB-VERSION", "2016-03-08")

此外,由于api.sandbox.coinbase.com不可用,因此不再支持沙箱了吗?!

亲切的问候

1 个答案:

答案 0 :(得分:1)

对于bash / curl,问题是我与echo一起使用的hmac工具。以下为卷曲请求工作:

SIG=$(echo -n "${TIMESTAMP}GET/v2/accounts" | openssl dgst -sha256 -hmac "$COINBASE_SECRET" |cut -d' ' -f2);

关于golang,我比较了哈希值,得出的结论是我正在使用的当前库有些可疑。

我自己写了一个图书馆(https://github.com/Zauberstuhl/go-coinbase),现在它就像一个魅力。 我正在做同样的事情,除了我使用Sprintf进行最终编码,但这应该是相同的。

非常感谢!