golang 中的md5 hmacsha1算法的简单实现

Posted enumx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang 中的md5 hmacsha1算法的简单实现相关的知识,希望对你有一定的参考价值。

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

以上是关于golang 中的md5 hmacsha1算法的简单实现的主要内容,如果未能解决你的问题,请参考以下文章

MD5,sha1,sha256分别输出多少位啊?

Java HmacSHA1算法

HMAC加密的消息摘要码

HMACSHA1 加密算法

MD5、sha1、sha256分别输出多少位?

Java加密技术—— HMACSHA1 加密算法