Go语言中crypto/md5、crypto/sha1和crypto/sha256包用于生成哈希值,适用于数据完整性校验等场景;MD5通过md5.Sum()计算,输出128位哈希,虽不安全但可用于简单去重;SHA1使用sha1.Sum(),安全性高于MD5,但正被SHA-2取代;SHA256调用sha256.Sum256(),安全性高,适合密码存储与区块链;还可通过hash.Hash接口实现流式写入,如sha256.New()配合Write方法处理大文件;建议敏感场景避免使用MD5和SHA1。

在Go语言中,crypto/md5 和 crypto/sha1、crypto/sha256 等包用于生成数据的哈希值。这些哈希函数常用于校验数据完整性、生成唯一标识等场景。下面通过具体示例展示如何使用这些包进行哈希计算。
MD5 哈希计算
MD5 是一种广泛使用的哈希算法,尽管安全性较低,不推荐用于加密场景,但仍可用于文件校验或简单去重。
导入 crypto/md5 包 使用 md5.Sum() 计算字节切片的哈希值 通常将结果格式化为十六进制字符串输出
示例代码:
package mainimport ( "crypto/md5" "fmt")func main() { data := []byte("hello world") hash := md5.Sum(data) fmt.Printf("MD5: %xn", hash) // 输出:b10a8db164e0754105b7a99be72e3fe5}
SHA1 哈希计算
SHA-1 比 MD5 更安全,但目前也逐渐被更安全的 SHA-2 取代。适用于一般性校验。
立即学习“go语言免费学习笔记(深入)”;
使用 crypto/sha1 包 调用 sha1.Sum() 获取哈希值
示例代码:
package mainimport ( "crypto/sha1" "fmt")func main() { data := []byte("hello world") hash := sha1.Sum(data) fmt.Printf("SHA1: %xn", hash) // 输出:2aae6c35c94fcfb415dbe95f408b9ce91ee846ed}
SHA256 哈希计算
SHA-256 是 SHA-2 系列中最常用的算法,安全性高,适合密码存储、区块链等场景。
导入 crypto/sha256 使用 sha256.Sum256() 或 sha256.Sum() 计算哈希
示例代码:
package mainimport ( "crypto/sha256" "fmt")func main() { data := []byte("hello world") hash := sha256.Sum256(data) fmt.Printf("SHA256: %xn", hash) // 输出:a591a6d40bf420404a011733cfb7b190d62c65bf0bcda32b57b277d9ad9f146e}
通用哈希接口:使用 hash.Hash 接口
如果需要统一处理不同算法,可以使用 hash.Hash 接口,支持 Write 方法流式写入数据。
示例:以 SHA256 为例演示接口用法
package mainimport ( "crypto/sha256" "fmt")func main() { h := sha256.New() h.Write([]byte("hello")) h.Write([]byte(" ")) h.Write([]byte("world")) sum := h.Sum(nil) // 追加到提供的切片,nil 表示新建 fmt.Printf("Streaming SHA256: %xn", sum)}
这种方式适合处理大文件或网络流数据。
基本上就这些。Go 的哈希包设计简洁,标准库支持良好,选择合适算法即可满足大多数需求。注意:敏感场景避免使用 MD5 和 SHA1。
以上就是Golang crypto/md5与sha哈希计算示例的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1408560.html
微信扫一扫
支付宝扫一扫