登录
首页 >  Golang >  Go问答

HMAC 在 Python3 与 Golang 中生成不同的字符串

来源:stackoverflow

时间:2024-03-07 21:12:25 470浏览 收藏

有志者,事竟成!如果你在学习Golang,那么本文《HMAC 在 Python3 与 Golang 中生成不同的字符串》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

我有一个 golang 函数,可以计算给定密钥和挑战的 hmac 。 go代码是

func get_hmac64(psk string, challenge string) string {
    mac := hmac.new(sha3.new256, []byte(psk))
    mac.write([]byte(challenge))
    macsum := mac.sum(nil)
    var macsumb64 = make([]byte, (len(macsum)*8+5)/6)
    base64.urlencoding.encode(macsumb64, macsum)
    return string(macsumb64)
}

我将其翻译为 python3,如下所示。

def get_hmac64(self, psk: str, challenge: str) ->str:
        """
        This generates a different string for same psk and challenge between Golang and Python3
        """
        psk_bytes = bytes(psk, "utf-8")
        challenge_bytes = bytes(challenge, "utf-8")
        mac = hmac.new(psk_bytes, challenge_bytes, hashlib.sha3_256)
        mac_digest = mac.digest()
        b64_encoded = base64.b64decode(mac_digest)
        return b64_encoded.decode("utf-8")
  
    print(get_hmac("abc", "def"))

对于python实现,返回的字符串是m1p63mj5ytdyuaj4m2umtekbgrg/k3azhcw/tjis1k = zqbendczb = zqbendczb,而gozqbgozqbend_qblin的gozqblin_qblin的zqblis-与zqbgozqbend is zq qul s s syper-qul is zq” 3mat

如果 keychallengehash 对于跨语言的 hmac 实现保持相同,那么该值是否应该相同?如果是这样,我在 python 翻译中错过了哪一步?


正确答案


以下代码给出的结果与您为 python 代码报告的结果相同:

func get_hmac64(psk string, challenge string) string {
    mac := hmac.New(sha3.New256, []byte(psk))
    mac.Write([]byte(challenge))
    macSum := mac.Sum(nil)
    return base64.StdEncoding.EncodeToString(macSum)
}

(完整代码为 https://go.dev/play/p/5lWG-jMfELz)。 两个区别是我使用了 sha3.new256 而不是奇怪的 newdragonhash,并且我通过简单地使用 .encodetostring() 方法修复了 base64 编码。

本篇关于《HMAC 在 Python3 与 Golang 中生成不同的字符串》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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