使用crypto/md5可生成字符串或文件的MD5哈希,适用于校验和与文件指纹;通过md5.New()创建实例,Write或io.WriteString写入数据,Sum(nil)获取哈希值,但不推荐用于安全场景。

在Golang中使用 crypto/md5 生成哈希非常简单。尽管MD5由于安全性问题不推荐用于密码或敏感数据的加密,但它仍可用于校验和、文件指纹等非安全场景。
导入 crypto/md5 包
要使用MD5功能,需要导入标准库中的 crypto/md5 包:
import "crypto/md5"对字符串生成MD5哈希
以下是一个将字符串转换为MD5哈希值的示例:
package mainimport (
"crypto/md5"
"fmt"
"io"
)
func main() {
data := "hello world"
hash := md5.New()
hash.Write([]byte(data))
result := hash.Sum(nil)
fmt.Printf("%x\n", result) // 输出:5eb63bbbe01eeed093cb22bb8f5acdc3
}
说明:
立即学习“go语言免费学习笔记(深入)”;
- md5.New() 创建一个新的哈希实例。
- hash.Write() 写入字节流(接受 []byte)。
- hash.Sum(nil) 返回最终的哈希值([]byte),%x 格式化输出为十六进制字符串。
更简洁的方式:使用 io.WriteString
对于字符串输入,推荐使用 io.WriteString 避免不必要的类型转换:
hash := md5.New()io.WriteString(hash, "hello world")
fmt.Printf("%x\n", hash.Sum(nil))
处理文件或大块数据
MD5也适合计算文件哈希。可以边读文件边写入hash对象:
file, err := os.Open("example.txt")if err != nil {
log.Fatal(err)
}
defer file.Close()
hash := md5.New()
if _, err := io.Copy(hash, file); err != nil {
log.Fatal(err)
}
fmt.Printf("%x\n", hash.Sum(nil))
基本上就这些。使用 crypto/md5 时注意它不是加密工具,仅用于完整性校验或唯一标识生成。如果需要更高安全性,应改用 crypto/sha256 或其他更强算法。










