Go SHA1 散列

SHA1散列经常用来计算二进制或者大文本数据的短标识值。git版本控制系统用SHA1来标识受版本控制的文件和目录。这里介绍Go中如何计算SHA1散列值。
Go在crypto/*包里面实现了几个常用的散列函数。

  1. package main
  2. import "crypto/sha1"
  3. import "fmt"
  4. func main() {
  5. s := "sha1 this string"
  6. // 生成一个hash的模式是`sha1.New()`,`sha1.Write(bytes)`
  7. // 然后是`sha1.Sum([]byte{})`,下面我们开始一个新的hash
  8. // 示例
  9. h := sha1.New()
  10. // 写入要hash的字节,如果你的参数是字符串,使用`[]byte(s)`
  11. // 把它强制转换为字节数组
  12. h.Write([]byte(s))
  13. // 这里计算最终的hash值,Sum的参数是用来追加而外的字节到要
  14. // 计算的hash字节里面,一般来讲,如果上面已经把需要hash的
  15. // 字节都写入了,这里就设为nil就可以了
  16. bs := h.Sum(nil)
  17. // SHA1散列值经常以16进制的方式输出,例如git commit就是
  18. // 这样,所以可以使用`%x`来将散列结果格式化为16进制的字符串
  19. fmt.Println(s)
  20. fmt.Printf("%x\n", bs)
  21. }

运行结果

  1. sha1 this string
  2. cf23df2207d99a74fbe169e3eba035e633b65d94