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)
}
相关推荐
沐知全栈开发2 小时前
HTML DOM 访问
开发语言
脑袋大大的3 小时前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
二进制person4 小时前
Java SE--方法的使用
java·开发语言·算法
OneQ6664 小时前
C++讲解---创建日期类
开发语言·c++·算法
码农不惑5 小时前
2025.06.27-14.44 C语言开发:Onvif(二)
c语言·开发语言
Coding小公仔6 小时前
C++ bitset 模板类
开发语言·c++
小赖同学啊7 小时前
物联网数据安全区块链服务
开发语言·python·区块链
shimly1234567 小时前
bash 脚本比较 100 个程序运行时间,精确到毫秒,脚本
开发语言·chrome·bash
IT_10247 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle