hmac是Hash-based Message Authentication Code的简写,就是指哈希消息认证码,包含有很多种哈希加密算法,sha256是其中一种。
golang代码实现入戏:
package main
import (
"crypto/hmac"
"crypto/sha256"
"encoding/base64"
"encoding/hex"
"fmt"
)
const (
message = "hello world!"
secret = "0933e54e76b24731a2d84b6b463ec04c"
)
func ComputeHmacSha256(message string, secret string) string {
key := []byte(secret)
h := hmac.New(sha256.New, key)
h.Write([]byte(message))
// fmt.Println(h.Sum(nil))
sha := hex.EncodeToString(h.Sum(nil))
// fmt.Println(sha)
// hex.EncodeToString(h.Sum(nil))
return base64.StdEncoding.EncodeToString([]byte(sha))
}
func main() {
fmt.Println(ComputeHmacSha256(message, secret))
}
注意:计算hamc_sha256时,是否需要转成十六进制,取决于自己的需要,本文代码中注释掉该行代码:
hex.EncodeToString(h.Sum(nil))