简介
本实验旨在演示如何在 Go 语言中计算 SHA256 哈希值。SHA256 哈希值通常用于计算二进制或文本块的简短标识。
本实验旨在演示如何在 Go 语言中计算 SHA256 哈希值。SHA256 哈希值通常用于计算二进制或文本块的简短标识。
给定一个字符串,计算其 SHA256 哈希值。
crypto/sha256 和 fmt 包。sha256.New() 函数创建一个新的哈希。Write 函数将字符串的字节写入哈希。Sum 函数获取最终的哈希结果作为字节切片。## 运行该程序会计算哈希值并以人类可读的十六进制格式打印出来。
$ go run sha256-hashes.go
sha256 this string
1af1dfa857bf1d8814fe1af8983c18080019922e557f15a8a...
## 你可以使用与上述类似的模式计算其他哈希值。例如,要计算
## SHA512 哈希值,导入 `crypto/sha512` 并使用
## `sha512.New()`。
## 请注意,如果你需要加密安全的哈希值,
## 你应该仔细研究
## [哈希强度](https://en.wikipedia.org/wiki/Cryptographic_hash_function)!
以下是完整代码:
// [_SHA256 哈希值_](https://en.wikipedia.org/wiki/SHA-2) 常用于计算二进制
// 或文本块的简短标识。例如,TLS/SSL 证书使用 SHA256 来计算证书的签名。以下是在 Go 中计算
// SHA256 哈希值的方法。
package main
// Go 在各种 `crypto/*` 包中实现了多个哈希函数。
import (
"crypto/sha256"
"fmt"
)
func main() {
s := "sha256 this string"
// 这里我们从一个新的哈希开始。
h := sha256.New()
// `Write` 期望传入字节。如果你有一个字符串 `s`,
// 使用 `[]byte(s)` 将其转换为字节。
h.Write([]byte(s))
// 这会获取最终的哈希结果作为字节
// 切片。`Sum` 的参数可用于追加到现有的字节切片:通常不需要。
bs := h.Sum(nil)
fmt.Println(s)
fmt.Printf("%x\n", bs)
}
本实验演示了如何使用 crypto/sha256 包在 Go 语言中计算 SHA256 哈希值。通过遵循要求并完成待办事项部分,程序可以计算给定字符串的 SHA256 哈希值。