HMAC是密钥相关的哈希运算消息认证码,HMAC运算利用哈希算法,以一个密钥和一个消息为输入,生成一个消息摘要作为输出。 主要用于验证接口签名~ md5 、hmac、sha1算法的简单实现: ~~~ package main import ( "crypto/hmac" "crypto/md5" "crypto/sha1" "encoding/hex" "fmt" ) func Md5(data string) string { md5 := md5.New() md5.Write([]byte(data)) md5Data := md5.Sum([]byte("")) return hex.EncodeToString(md5Data) } func Hmac(key, data string) string { hmac := hmac.New(md5.New, []byte(key)) hmac.Write([]byte(data)) return hex.EncodeToString(hmac.Sum([]byte(""))) } func Sha1(data string) string { sha1 := sha1.New() sha1.Write([]byte(data)) return hex.EncodeToString(sha1.Sum([]byte(""))) } func main() { fmt.Println(Md5("hello")) fmt.Println(Hmac("key2", "hello")) fmt.Println(Sha1("hello")) } ~~~ 输出结果: ~~~ 5d41402abc4b2a76b9719d911017c592 f1b90b4efd0e5c7db52dfa0efd6521a3 aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d ~~~