Go语言之城 - 程序示例: SHA256 散列

SHA256 散列(hash) 经常用于生成二进制文件或者文本块的短标识。 例如,TLS/SSL 证书使用 SHA256 来计算一个证书的签名。 这是 Go 中如何进行 SHA256 散列计算的例子。

package main

Go 在多个 crypto/* 包中实现了一系列散列函数。

import (
    "crypto/sha256"
    "fmt"
)
func main() {
    s := "sha256 this string"

这里我们从一个新的散列开始。

    h := sha256.New()

写入要处理的字节。如果是一个字符串, 需要使用 []byte(s) 将其强制转换成字节数组。

    h.Write([]byte(s))

Sum 得到最终的散列值的字符切片。Sum 接收一个参数, 可以用来给现有的字符切片追加额外的字节切片:但是一般都不需要这样做。

    bs := h.Sum(nil)

SHA256 值经常以 16 进制输出,例如在 git commit 中。 我们这里也使用 %x 来将散列结果格式化为 16 进制字符串。

    fmt.Println(s)
    fmt.Printf("%x\n", bs)
}

运行程序计算散列值,并以可读的 16 进制格式输出。

$ go run sha256-hashes.go
sha256 this string
1af1dfa857bf1d8814fe1af8983c18080019922e557f15a8a...

你可以使用和上面相似的方式来计算其他形式的散列值。 例如,计算 SHA512 散列, 引入 crypto/sha512 并使用 sha512.New() 方法。

注意,如果你需要密码学上的安全散列,你需要仔细的研究一下 加密散列函数

下一个例子: Base64 编码