代码拉取完成,页面将自动刷新
// Package utils
// Copyright: Copyright (c) 2020<br>
// Company: 易宝支付(YeePay)<br>
// @author : yunmei.wu
// @time : 2023/3/14 10:23 AM
package utils
import (
"crypto"
"crypto/rand"
"crypto/rsa"
"crypto/sha256"
"crypto/x509"
"encoding/base64"
"encoding/pem"
"errors"
"strings"
)
// RsaSignBase64 base64UrlEncode签名
func RsaSignBase64(content string, privateKey string, hash crypto.Hash) (string, error) {
signature, err := Sign(content, privateKey, hash)
if err != nil {
return "", err
}
return base64.RawURLEncoding.EncodeToString(signature), nil
}
// VerifySign 验签
func VerifySign(content string, signature string, pubKey string, hash crypto.Hash) bool {
pubKey = FormatPemKey(pubKey, "PUBLIC KEY")
publicKey, err := ParsePublicKey(pubKey)
if err != nil {
return false
}
var sig []byte
if strings.Contains(signature, "*") || strings.Contains(signature, "+") || strings.Contains(signature, "=") {
sig, _ = base64.StdEncoding.DecodeString(signature)
} else {
sig, _ = base64.RawURLEncoding.DecodeString(signature)
}
return Verify([]byte(content), sig, publicKey, crypto.SHA256)
}
func Verify(content []byte, signature []byte, pub *rsa.PublicKey, hash crypto.Hash) bool {
hashed := sha256.Sum256(content)
err := rsa.VerifyPKCS1v15(pub, hash, hashed[:], signature)
if err != nil {
return false
}
return true
}
// Sign rsa签名
func Sign(content string, privateKey string, hash crypto.Hash) ([]byte, error) {
shaNew := sha256.New()
shaNew.Write([]byte(content))
hashed := shaNew.Sum(nil)
priKey, err := ParsePrivateKey(privateKey)
if err != nil {
return nil, err
}
signature, err := rsa.SignPKCS1v15(rand.Reader, priKey.(*rsa.PrivateKey), hash, hashed)
return signature, err
}
func ParsePrivateKey(privateKey string) (any, error) {
privateKey = FormatPemKey(privateKey, "PRIVATE KEY")
// 2、解码私钥字节,生成加密对象
block, _ := pem.Decode([]byte(privateKey))
if block == nil {
return nil, errors.New("私钥信息错误!")
}
// 3、解析DER编码的私钥,生成私钥对象
priKey, err := x509.ParsePKCS8PrivateKey(block.Bytes)
if err != nil {
return nil, err
}
return priKey, nil
}
func ParsePublicKey(publicKey string) (*rsa.PublicKey, error) {
block, _ := pem.Decode([]byte(publicKey))
if block == nil {
return nil, errors.New("公钥信息错误!")
}
pubKey, err := x509.ParsePKIXPublicKey(block.Bytes)
if err != nil {
return nil, err
}
return pubKey.(*rsa.PublicKey), nil
}
// FormatPemKey /**
func FormatPemKey(yopFormKey string, pemHeader string) string {
var sb = strings.Builder{}
sb.WriteString("-----BEGIN ")
sb.WriteString(pemHeader)
sb.WriteString("-----\n")
for i := 0; i < len(yopFormKey); i++ {
sb.WriteString(string([]rune(yopFormKey)[i]))
if (i+1)%64 == 0 {
sb.WriteString("\n")
}
}
sb.WriteString("\n-----END ")
sb.WriteString(pemHeader)
sb.WriteString("-----\n")
return sb.String()
}
func RsaDecrypt(priKey string, cipher string) ([]byte, error) {
privateKey, _ := ParsePrivateKey(priKey)
cipherBytes, _ := base64.RawURLEncoding.DecodeString(cipher)
return rsa.DecryptPKCS1v15(rand.Reader, privateKey.(*rsa.PrivateKey), cipherBytes)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。