gpt4 book ai didi

Golang crypto/hmac 全局哈希对象

转载 作者:数据小太阳 更新时间:2023-10-29 03:36:41 25 4
gpt4 key购买 nike

我尝试使用全局 hmac 哈希来生成签名。代码运行良好,但生成的签名不满足第 3 方集成检查器的要求。如果将为每个“签名生成”过程创建 hmac 哈希,它将正常工作。

工作正常 - 签名被第 3 方接受:

func tokenSignatureFunc(key string) tokenSignType {
signToken := func(token string) []byte {
h := hmac.New(sha256.New, []byte(key))
h.Write([]byte(token))
signature := h.Sum(nil)
base64Signature := make([]byte, base64.StdEncoding.EncodedLen(len(signature)))
base64.StdEncoding.Encode(base64Signature, signature)
return base64Signature
}
return signToken
}

不起作用 - 第 3 方不接受签名:

func tokenSignatureFunc(key string) tokenSignType {
h := hmac.New(sha256.New, []byte(key))
signToken := func(token string) []byte {
h.Write([]byte(token))
signature := h.Sum(nil)
base64Signature := make([]byte, base64.StdEncoding.EncodedLen(len(signature)))
base64.StdEncoding.Encode(base64Signature, signature)
return base64Signature
}
return signToken
}

最佳答案

试试这个,它可能由于 base64 填充而失败。使用 RawStdEncoding 代替

func HMAC256(payload string, secret string) string {
sig := hmac.New(sha256.New,[]byte(secret))
sig.Write([]byte(payload))
return b64Encode(string(sig.Sum(nil)[:]))
}


func b64Encode(text string) string {
return base64.RawStdEncoding.EncodeToString([]byte(text))
}

关于Golang crypto/hmac 全局哈希对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52177885/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com