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

时间:2019-01-10 05:05:10

标签: go hash cracking

我正在构建一个使用golang暴力破解密码的程序。密码哈希的格式是将md5哈希应用到初始密码的1000x,然后再使用。 (我显示的代码仅适用此5x)

md5(md5(md5(md5(....(md5(password))))))

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))

实现此迭代哈希的一种好/成功方法是什么?

1 个答案:

答案 0 :(得分:0)

也许我误会了您的问题,但这是您要寻找的吗?

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

我知道您正在尝试在您的版本中重用哈希器,但是据我所知,这不是打算使用该库的方式。您写它来计算单个哈希,而不是舍入。