Go 利用crypto实现sha512计算方法
SHA-2,名称来自于安全散列算法2(英语:Secure Hash Algorithm 2)的缩写,一种密码散列函数算法标准,由美国国家安全局研发,由美国国家标准与技术研究院(NIST)在2001年发布。属于SHA算法之一,是SHA-1的后继者。其下又可再分为六个不同的算法标准,包括了:SHA-224、SHA-256、SHA-384、SHA-512、SHA-512/224、SHA-512/256。
package main
import (
"crypto/sha512"
"fmt"
"io"
)
func main() {
fmt.Println("go crypto sha512 demo.")
str1 := "https://const.net.cn"
str2 := "/"
w := sha512.New()
io.WriteString(w, str1)
io.WriteString(w, str2)
hashstr := fmt.Sprintf("sha512 = %x", w.Sum(nil))
fmt.Println(hashstr)
}
输出:
go run .
go crypto sha512 demo.
sha512 = dee0877970a321da947b39223110525fa0d9a47d703bce0c5cd39066e25b1078b76d21d83657c35451484db62e5ef80e43a33769b1f626bb8940ad3890e64fd5
echo -n "https://const.net.cn/" | openssl dgst -sha512
(stdin)= dee0877970a321da947b39223110525fa0d9a47d703bce0c5cd39066e25b1078b76d21d83657c35451484db62e5ef80e43a33769b1f626bb8940ad3890e64fd5