用golang实现对接java版的国密算法(Sm2SignWithSm3)

golang 对接 java 版的国密算法(Sm2SignWithSm3)

第三方加密算法升级国密SM2,找了好久才解决,直接上代码

需要依赖大神的包

https://github.com/ZZMarquis/gm

直接上源码

package sm2

import (
	"encoding/base64"
	"encoding/hex"
	"encoding/json"
	"github.com/ZZMarquis/gm/sm2"
	"github.com/gin-gonic/gin"
	"github.com/sirupsen/logrus"
	"github.com/spf13/cast"
	"io/ioutil"
	"os"
)

type strings struct {
	Strings string `json:"strings"`
}

func getPrivateKey(path string) string {
	str, _ := os.Getwd()
	separator := string(os.PathSeparator)
	f, err := ioutil.ReadFile(str + separator + "static" + separator + path + separator + "sm2PrivateKey.txt")
	if err != nil {
		logrus.Println("getPrivateKey error: ", err)
	}
	return cast.ToString(f)
}

func GetSign(ctx *gin.Context) {
	data, _ := ioutil.ReadAll(ctx.Request.Body)
	var tempStrings strings
	err := json.Unmarshal(data, &tempStrings)
	if err != nil {
		logrus.Println("GetSign get tempString err: ", err)
	}
	// 获取私钥
	privateKey := getPrivateKey(utils.Cfg.KeyPath)
	// 解码hex私钥
	privateKeyByte, err := hex.DecodeString(privateKey)
	if err != nil {
		logrus.Println("DecodeString privateKey error: ", err)
	}
	// 转成go版的私钥
	pri, err := sm2.RawBytesToPrivateKey(privateKeyByte)
	if err != nil {
		logrus.Println("RawBytesToPrivateKey error: ", err)
	}
	// 携带uid 的sign
	signature, err := sm2.Sign(pri, []byte("1234567812345678"), []byte(tempStrings.Strings))
	if err != nil {
		logrus.Println("Sign error: ", err)
	}
	// 转 base64
	sign := base64.StdEncoding.EncodeToString(signature)
	logrus.Println("** getSign: ", sign)
	ctx.String(200, sign)
}
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qls7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值