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

标签 go hash cracking

我正在构建一个使用 golang 来暴力破解密码的程序。密码哈希的格式是将 1000 倍应用于初始密码然后使用的 md5 哈希。 (我展示的代码只应用了这个 5x)

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

我知道您正试图在您的版本中重用散列器,但据我了解,这不是该库的预期用途。您写入它来计算单个哈希值,而不是轮数。

关于go - 如何在 Golang 中计算嵌套/迭代 MD5 哈希?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54122226/

相关文章:

arrays - 如何使用值中的键将哈希数组转换为哈希对象?

Python 多处理密码破解器

c# - 如何破解一个dBase文件的密码?

go - 合并多个错误字符串

xml - go中将数组编码为base64

go - 如何获得带有反射的自定义类型?

public-key-encryption - Forest 能破解公钥密码吗?

Golang 初学者,Windows : System cannot find file specified

hash - 如何从 []bytes 获取十六进制

.net - 如何强制 .net String GetHashCode() 的 32 位