Go语言中MD5和SHA系列哈希算法由crypto/md5、crypto/sha1、crypto/sha256、crypto/sha512等包提供,用于生成固定长度摘要,适用于数据校验、文件指纹等场景;MD5生成128位哈希值,通常表示为32位十六进制字符串;示例代码展示了对字符串计算MD5、SHA256和SHA512哈希值的过程,输出分别为5eb63bbbe01eeed093cb22bb8f5acdc3、b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9和3a6eb0790f39ac87c94f3856b2dd2c5d110e6811602261a9a923d3bb23adc8b798604939e761e875f1e807c096c897b32f3f8f9d7b3b0a3d14fcd770b61770bc

在Go语言中,MD5和SHA系列哈希算法由标准库中的 crypto/md5 和 crypto/sha1、crypto/sha256、crypto/sha512 等包提供支持。这些算法用于生成数据的固定长度摘要,常用于数据校验、文件指纹、密码存储等场景。
MD5 哈希实现
MD5 生成128位(16字节)的哈希值,通常以32位十六进制字符串表示。
示例:对字符串生成 MD5 哈希
package mainimport ( "crypto/md5" "fmt" "io")func main() { data := "hello world" hash := md5.New() io.WriteString(hash, data) result := fmt.Sprintf("%x", hash.Sum(nil)) fmt.Println("MD5:", result)}
输出:
立即学习“go语言免费学习笔记(深入)”;
MD5: 5eb63bbbe01eeed093cb22bb8f5acdc3
SHA 哈希实现(SHA1 / SHA256 / SHA512)
SHA 系列提供更强的安全性,其中 SHA256 和 SHA512 更常用于现代应用。
package mainimport ( "crypto/sha256" "crypto/sha512" "fmt" "io")func main() { data := "hello world" // SHA256 hash256 := sha256.New() io.WriteString(hash256, data) result256 := fmt.Sprintf("%x", hash256.Sum(nil)) fmt.Println("SHA256:", result256) // SHA512 hash512 := sha512.New() io.WriteString(hash512, data) result512 := fmt.Sprintf("%x", hash512.Sum(nil)) fmt.Println("SHA512:", result512)}
输出:
立即学习“go语言免费学习笔记(深入)”;
SHA256: b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
SHA512: 3a6eb0790f39ac87c94f3856b2dd2c5d110e6811602261a9a923d3bb23adc8b798604939e761e875f1e807c096c897b32f3f8f9d7b3b0a3d14fcd770b61770bc
处理文件的哈希计算
对于大文件,应使用 io.Copy 将文件内容写入哈希器,避免一次性加载全部内容到内存。
package mainimport ( "crypto/sha256" "fmt" "os")func main() { file, err := os.Open("example.txt") if err != nil { panic(err) } defer file.Close() hash := sha256.New() _, err = io.Copy(hash, file) if err != nil { panic(err) } result := fmt.Sprintf("%x", hash.Sum(nil)) fmt.Println("File SHA256:", result)}
通用哈希接口(使用 hash.Hash)
Go 的 hash.Hash 接口允许统一处理不同算法,提升代码复用性。
func computeHash(hash hash.Hash, data string) string { hash.Write([]byte(data)) return fmt.Sprintf("%x", hash.Sum(nil))}// 使用示例h := md5.New()fmt.Println(computeHash(h, "hello"))
基本上就这些。Go 的哈希接口设计简洁,配合标准库使用非常方便。注意:MD5 和 SHA1 已不推荐用于安全敏感场景,建议使用 SHA256 或更高强度算法。
以上就是Golang hash哈希算法 MD5/SHA实现的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1401332.html
微信扫一扫
支付宝扫一扫