登录
首页 >  Golang >  Go问答

如何在 Golang 中计算嵌套/迭代 MD5 哈希?

来源:stackoverflow

时间:2024-04-13 14:51:33 378浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《如何在 Golang 中计算嵌套/迭代 MD5 哈希?》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在构建一个使用 golang 暴力破解密码的程序。密码哈希值的格式是对初始密码应用 1000 倍的 md5 哈希值,然后使用该哈希值。 (我展示的代码仅应用了这 5 次)

md5(md5(md5(md5(....(md5(密码))))))

func hash(pw string) string {
    hasher := md5.new()

    data := []byte(pw)
    fmt.printf("initial data: %s\n", pw)

    for i := 0; i < 5; i++ {
        hasher.reset()
        hasher.write(data)
        sum := hasher.sum(nil)
        data = sum[:]
        fmt.printf("iteration %x has the hash: %x\n", i+1, data)
    }
    return hex.encodetostring(data)
}

此结果与使用命令行实用程序 md5sum 给出的结果不同。我的另一个尝试是使用,因为这是无状态的,但我仍然开始偏离第二轮哈希

sum := md5.Sum([]byte(data))

实现计算此迭代哈希的良好/成功方法是什么?


解决方案


也许我误解了你的问题,但这就是你要找的吗?

package main

import (
    "crypto/md5"
    "fmt"
    "io"
)

func main() {
    fmt.Printf("\nresult: %s", md5plus("123", 2))
}

func md5plus(text string, cost int) string {
    for i := 0; i < cost; i++ {
        fmt.Printf("Loop %d: %s", i+1, text)
        hash := md5.New()
        io.WriteString(hash, text)
        text = fmt.Sprintf("%x", hash.Sum(nil))
        fmt.Printf(" => %s\n", text)
    }

    return text
}

https://play.golang.org/p/ri-5m3RZ_8v

我意识到您正在尝试在您的版本中重用哈希器,但据我了解,这不是该库的用途。您写入它是为了计算单个哈希值,而不是轮次。

以上就是《如何在 Golang 中计算嵌套/迭代 MD5 哈希?》的详细内容,更多关于的资料请关注golang学习网公众号!

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