golang实现hmac_sha256加密

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))

 

 

 

你可能感兴趣的:(Golang,golang学习)