Go语言RSA加密算法的常用api整理(go-rsa文档)

go-rsa

安装

go get github.com/melf-xyzh/go-rsa

使用方法

sha1withrsa

签名
// 需要签名的文本
context := "helloworld" 
// 签名
sign, err := sha1withrsa.Sign(privateKey, context)
if err != nil {
	log.Fatalln(err)
}
fmt.Println(sign)
验签
// 验签
verify, err := sha1withrsa.RSAVerify(publicKey, context, sign)
if err != nil {
	return
}
fmt.Println(verify)

加密 / 解密

// 加密
encrypt, err := myrsa.RsaEncrypt(publicKey, content)
if err != nil {
	return
}
// 解密
data, err := myrsa.RsaDecrypt(privateKey,encrypt)
if err != nil {
	return
}

生成读取公私钥文件(pem格式 / PKCS1)

// 生成公钥文件(pem格式)
err = myrsa.CreatePrivatePem(privateKey, "")
if err != nil {
	log.Fatal(err)
}
// 读取私钥文件(pem格式)
err = myrsa.CreatePublicPem(publicKey, "")
if err != nil {
	log.Fatal(err)
}
// 读取私钥文件(pem格式)
privateKey, err = myrsa.ReadPrivatePem("cert/private.pem")
if err != nil {
    log.Fatal(err)
}
// 读取公钥文件(pem格式)
publicKey, err = myrsa.ReadPublicPem("cert/public.pem")
if err != nil {
    log.Fatal(err)
}

生成读取公私钥文件(ec格式 / PKCS8)

// 生成私钥文件(ec格式)
err = myrsa.CreatePrivateEC(privateKey, "cert/private.key")
if err != nil {
	log.Fatal(err)
}
// 生成公钥文件(ec格式)
err = myrsa.CreatePublicEC(publicKey, "cert/public.key")
if err != nil {
	log.Fatal(err)
}
// 读取私钥文件(ec格式)
privateKey, err = myrsa.ReadPrivateEC("cert/private.key")
if err != nil {
	log.Fatal(err)
}
// 读取公钥文件(ec格式)
publicKey, err = myrsa.ReadPublicEC("cert/public.key")
if err != nil {
	log.Fatal(err)
}

生成证书文件(CA)

// 生成CA证书
err = myrsa.CreateCertificate(publicKey, privateKey, "cert/ca/")
if err != nil {
	log.Fatal(err)
}
// 导入CA证书
certificate, err := myrsa.LoadCertificate("cert/ca/ca.crt")
if err != nil {
    log.Fatal(err)
}

PFX证书

// 从PFX证书中解析公私钥
privateKey, publicKey, err := pfx.GetPublicAndPrivateKeyFromPfx("zhengshu.pfx", "123456")
if err != nil {
	return
}
pfx.PrintPublicKey(publicKey)
pfx.PrintPrivateKey(privateKey)

参考文档:

https://blog.csdn.net/lady_killer9/article/details/118026802
https://ask.csdn.net/questions/1012311
https://blog.csdn.net/lady_killer9/article/details/118026802
https://blog.csdn.net/weixin_38299404/article/details/117341068
https://blog.csdn.net/youngZ_H/article/details/123625301
https://studygolang.com/articles/29971?fr=sidebar
https://www.csdn.net/tags/MtTaEgzsMDg0MDA0LWJsb2cO0O0O.html

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值