golang 版 E签宝请求签名鉴权方式

E签宝 请求签名鉴权方式说明

Go 复制代码
package utils

import (
	"crypto/hmac"
	"crypto/md5"
	"crypto/sha256"
	"encoding/base64"
	"fmt"
	"github.com/gogf/gf/v2/util/gconv"
)

type Sign struct {
    secret string
}

func NewSign(secret string) *Sign {
    return &Sign{secret}
}

// DoSign 计算签名
func (s Sign) DoSign(method, path, contentMD5, headers string) string {
    accept := "*/*"
    contentType := "application/json; charset=UTF-8"
    date := ""
    // 组合拼接待签名字符串
    canonicalString := fmt.Sprintf("%s\n%s\n%s\n%s\n%s\n", method, accept, contentMD5, contentType, date)
    if headers == "" {
       canonicalString = fmt.Sprintf("%s%s%s", canonicalString, headers, path)
    } else {
       canonicalString = fmt.Sprintf("%s%s\n%s", canonicalString, headers, path)
    }
    // 拼接字符串
    fmt.Println("拼接字符串:\n" + canonicalString + "\n")
    // 最后计算签名
    return s.doSignatureBase64(canonicalString, s.secret)
}

// doSignatureBase64 计算签名(HmacSHA256)
func (s Sign) doSignatureBase64(message, secret string) string {
    mac := hmac.New(sha256.New, []byte(secret))
    _, _ = mac.Write([]byte(message))
    encode := mac.Sum(nil)
    return base64.StdEncoding.EncodeToString(encode)
}

// DoContentMD5Base64 计算Body体的Content-MD5值
func (s Sign) DoContentMD5Base64(bodyData any) string {
    // 创建一个新的MD5 hasher对象
    md := md5.New()
    // 将byte数组写入hasher中计算MD5值
    md.Write([]byte(gconv.String(bodyData)))
    // 获取MD5值的byte数组表示(16 bytes)
    md5Bytes := md.Sum(nil)
    // 转base64
    return base64.StdEncoding.EncodeToString(md5Bytes)
}
相关推荐
rafael(一只小鱼)1 小时前
AI运维开发平台学习
java·开发语言
b***74881 小时前
C++在系统中的内存对齐
开发语言·c++
散峰而望1 小时前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
4***14902 小时前
C++在系统中的编译优化
开发语言·c++
田姐姐tmner2 小时前
Python切片
开发语言·python
oioihoii2 小时前
C++程序执行起点不是main:颠覆你认知的真相
开发语言·c++
Digitally2 小时前
如何通过蓝牙将联系人从 iPhone 传输到 Android
android·ios·iphone
90后的晨仔2 小时前
2025年11月27日年解决隐私清单导致审核总是提示二进制无效的问题
ios
周杰伦fans2 小时前
C# 中的**享元工厂**模式
开发语言·数据库·c#
u***u6852 小时前
C++在系统中的异常处理
java·开发语言·c++