登录
首页 >  Golang >  Go问答

Golang crypto/hmac 全局哈希对象

来源:stackoverflow

时间:2024-04-18 08:09:28 312浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是Golang学习者,那么本文《Golang crypto/hmac 全局哈希对象》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!

问题内容

我尝试使用全局 hmac 哈希来生成签名。代码运行良好,但生成的签名不满足第三方集成检查器的要求。如果为每个“签名生成”过程创建 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
}

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

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学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>