iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Go语言怎么实现RSA加密解密
  • 321
分享到

Go语言怎么实现RSA加密解密

2023-06-14 23:06:55 321人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Go语言怎么实现RSA加密解密,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。go是什么golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可以直接部署到目标

这篇文章将为大家详细讲解有关Go语言怎么实现RSA加密解密,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

go是什么

golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可以直接部署到目标机器而无需额外的依赖,所以golang的性能优于其他的解释性语言,且可以在golang中使用goroutine来实现并发性,它提供了一个非常优雅的goroutine调度程序系统,可以很容易地生成数百万个goroutine。

RSA是一种非对称加密算法,它的名字是由它的三位开发者,即RonRivest、AdiShamir和LeonardAdleman 的姓氏的首字母组成的(Rivest-Shamir-Adleman ),可用于数据加密和数字签名。

用于数据加密时,消息发送方利用对方的公钥进行加密,消息接受方收到密文时使用自己的私钥进行解密。

实现代码如下:

import ("crypto/rsa""crypto/rand""crypto/x509""os""encoding/pem""fmt")//生成RSA私钥和公钥,保存到文件中func GenerateRSAKey(bits int){//GenerateKey函数使用随机数据生成器random生成一对具有指定字位数的RSA密钥//Reader是一个全局、共享的密码用强随机数生成器privateKey, err := rsa.GenerateKey(rand.Reader, bits)if err!=nil{panic(err)}//保存私钥//通过x509标准将得到的ras私钥序列化为ASN.1 的 DER编码字符串X509PrivateKey := x509.MarshalPKCS1PrivateKey(privateKey)//使用pem格式对x509输出的内容进行编码//创建文件保存私钥privateFile, err := os.Create("private.pem")if err!=nil{panic(err)}defer privateFile.Close()//构建一个pem.Block结构体对象privateBlock:= pem.Block{Type: "RSA Private Key",Bytes:X509PrivateKey}//将数据保存到文件pem.Encode(privateFile,&privateBlock)//保存公钥//获取公钥的数据publicKey:=privateKey.PublicKey//X509对公钥编码X509PublicKey,err:=x509.MarshalPKIXPublicKey(&publicKey)if err!=nil{panic(err)}//pem格式编码//创建用于保存公钥的文件publicFile, err := os.Create("public.pem")if err!=nil{panic(err)}defer publicFile.Close()//创建一个pem.Block结构体对象publicBlock:= pem.Block{Type: "RSA Public Key",Bytes:X509PublicKey}//保存到文件pem.Encode(publicFile,&publicBlock)}//RSA加密func RSA_Encrypt(plainText []byte,path string)[]byte{//打开文件file,err:=os.Open(path)if err!=nil{panic(err)}defer file.Close()//读取文件的内容info, _ := file.Stat()buf:=make([]byte,info.Size())file.Read(buf)//pem解码block, _ := pem.Decode(buf)//x509解码publicKeyInterface, err := x509.ParsePKIXPublicKey(block.Bytes)if err!=nil{panic(err)}//类型断言publicKey:=publicKeyInterface.(*rsa.PublicKey)//对明文进行加密cipherText, err := rsa.EncryptPKCS1v15(rand.Reader, publicKey, plainText)if err!=nil{panic(err)}//返回密文return cipherText}//RSA解密func RSA_Decrypt(cipherText []byte,path string) []byte{//打开文件file,err:=os.Open(path)if err!=nil{panic(err)}defer file.Close()//获取文件内容info, _ := file.Stat()buf:=make([]byte,info.Size())file.Read(buf)//pem解码block, _ := pem.Decode(buf)//X509解码privateKey, err := x509.ParsePKCS1PrivateKey(block.Bytes)if err!=nil{panic(err)}//对密文进行解密plainText,_:=rsa.DecryptPKCS1v15(rand.Reader,privateKey,cipherText)//返回明文return plainText}

测试代码如下:

func main(){ //生成密钥对,保存到文件 GenerateRSAKey(2048) message:=[]byte("hello world") //加密 cipherText:=RSA_Encrypt(message,"public.pem") fmt.Println("加密后为:",string(cipherText)) //解密 plainText := RSA_Decrypt(cipherText, "private.pem") fmt.Println("解密后为:",string(plainText))}

测试结果如下:

Go语言怎么实现RSA加密解密

补充:golang中关于RSA加密、解密、签名、验签的总结

golang中关于RSA的加密、解密、签名、验签的使用主要在于使用x509及rsa package下相关的方法。

gocrypt是本人对一般常用的加/解密、签名/验签、hash的封装库,欢迎大家使用。

以下总结相关的各种变化类型:

1.秘钥、加密/签名字符串加密的格式

目前主要见到有hex及base64

(1)hex

针对hex的加解密

hex.DecodeString(s string)//解密hex.EncodeToString(src []byte) string//加密

(2)base64

base64.StdEncoding.DecodeString(s string) ([]byte, error)//解密base64.StdEncoding.EncodeToString(src []byte) string//加密

2.私钥的格式

解析私钥的方式如下:

(1)PKCS1

x509.ParsePKCS1PrivateKey(der []byte) (key interface{}, err error)

(2)PKCS8

x509.ParsePKCS8PrivateKey(der []byte) (key interface{}, err error)

3.采用的数字签名算法SHA

以下为RSA sign的不同说明:

(1)SHA1

hash := sha1.New() hash.Write([]byte(originalData)) encryptedData, err := rsa.SignPKCS1v15(rand.Reader, prvKey, crypto.SHA1, hash.Sum(nil))

(2)SHA256

hash := sha256.New() hash.Write([]byte(originalData)) encryptedData, err := rsa.SignPKCS1v15(rand.Reader, prvKey, crypto.SHA256, hash.Sum(nil))

4.RSA使用类型

主要有加密/解密、签名/验签4种方式,且加密/解密与签名/验签均是一个相反的过程。两对是根据对公钥及私钥的使用划分的。

加密/解密是采用公钥加密,私钥解密。

签名/验签是采用私钥签名,公钥验签。

(1)加密

rsa.EncryptPKCS1v15(rand io.Reader, pub *PublicKey, msg []byte) ([]byte, error)

(2)解密

rsa.DecryptPKCS1v15(rand io.Reader, priv *PrivateKey, ciphertext []byte) ([]byte, error)

(3)签名

rsa.SignPKCS1v15(rand io.Reader, priv *PrivateKey, hash crypto.Hash, hashed []byte) ([]byte, error)

(4)验签

rsa.VerifyPKCS1v15(pub *PublicKey, hash crypto.Hash, hashed []byte, sig []byte) error

5.具体的使用示例

(1)加密:采用sha1算法加密后转base64格式func RsaEncryptWithSha1Base64(originalData,publicKey string)(string,error){   key, _ := base64.StdEncoding.DecodeString(publicKey)   pubKey, _ := x509.ParsePKIXPublicKey(key)   encryptedData,err:=rsa.EncryptPKCS1v15(rand.Reader, pubKey.(*rsa.PublicKey), []byte(originalData))   return base64.StdEncoding.EncodeToString(encryptedData),err}(2)解密:对采用sha1算法加密后转base64格式的数据进行解密(私钥PKCS1格式)func RsaDecryptWithSha1Base64(encryptedData,privateKey string)(string,error){   encryptedDecodeBytes,err:=base64.StdEncoding.DecodeString(encryptedData)   if err!=nil {      return "",err   }   key,_:=base64.StdEncoding.DecodeString(privateKey)   prvKey,_:=x509.ParsePKCS1PrivateKey(key)   originalData,err:=rsa.DecryptPKCS1v15(rand.Reader,prvKey,encryptedDecodeBytes)   return string(originalData),err}(3)签名:采用sha1算法进行签名并输出为hex格式(私钥PKCS8格式)func RsaSignWithSha1Hex(data string, prvKey string) (string, error) {   keyByts, err := hex.DecodeString(prvKey)   if err != nil {      fmt.Println(err)      return "", err   }   privateKey, err := x509.ParsePKCS8PrivateKey(keyByts)   if err != nil {      fmt.Println("ParsePKCS8PrivateKey err", err)      return "", err   }   h := sha1.New()   h.Write([]byte([]byte(data)))   hash := h.Sum(nil)   signature, err := rsa.SignPKCS1v15(rand.Reader, privateKey.(*rsa.PrivateKey), crypto.SHA1, hash[:])   if err != nil {      fmt.Printf("Error from signing: %s\n", err)      return "", err   }   out := hex.EncodeToString(signature)   return out, nil}(4)验签:对采用sha1算法进行签名后转base64格式的数据进行验签func RsaVerySignWithSha1Base64(originalData, signData, pubKey string) error{   sign, err := base64.StdEncoding.DecodeString(signData)   if err != nil {      return err   }   public, _ := base64.StdEncoding.DecodeString(pubKey)   pub, err := x509.ParsePKIXPublicKey(public)   if err != nil {      return err   }   hash := sha1.New()   hash.Write([]byte(originalData))   return rsa.VerifyPKCS1v15(pub.(*rsa.PublicKey), crypto.SHA1, hash.Sum(nil), sign)}

关于“Go语言怎么实现RSA加密解密”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: Go语言怎么实现RSA加密解密

本文链接: https://www.lsjlt.com/news/275825.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go语言怎么实现RSA加密解密
    这篇文章将为大家详细讲解有关Go语言怎么实现RSA加密解密,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。go是什么golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可以直接部署到目标...
    99+
    2023-06-14
  • Go语言 如何实现RSA加密解密
    RSA是一种非对称加密算法,它的名字是由它的三位开发者,即RonRivest、AdiShamir和LeonardAdleman 的姓氏的首字母组成的(Rivest-Shamir-Ad...
    99+
    2024-04-02
  • python rsa加密解密怎么实现
    在Python中,可以使用`cryptography`库来实现RSA加密和解密。以下是一个示例: from cryptography...
    99+
    2023-10-26
    python
  • Python怎么实现RSA加密解密
    这篇文章主要介绍了Python怎么实现RSA加密解密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python怎么实现RSA加密解密文章都会有所收获,下面我们一起来看看吧。一、安装模块pip inst...
    99+
    2023-06-30
  • Python实现RSA加密解密
    目录前言一、安装模块二、生成密钥对三、加密四、解密五、完整代码前言 加密技术在数据安全存储,数据传输中发挥着重要作用,能够保护用户隐私数据安全,防止信息窃取。RSA是一种非对称加密技...
    99+
    2024-04-02
  • PHP实现RSA加密解密
    目录 安装phpseclib  代码编写 1.依赖引用 2.创建密钥 3.公钥加密 4.私钥解密 总结   安装phpseclib PHP安全通信库phpseclib,可以使用它来操作OpenSSL、GMP、libnaid或mcrypt...
    99+
    2023-09-08
    RSA phpseclib php 非对称加密
  • 怎么利用Python实现RSA加密解密
    这篇文章主要介绍“怎么利用Python实现RSA加密解密”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么利用Python实现RSA加密解密”文章能帮助大家解决问题。RSA加密实验基本流程:一、选取...
    99+
    2023-06-29
  • java怎么实现rsa加密解密文件
    要在Java中实现RSA加密和解密文件,可以使用Java Cryptography Architecture(JCA)提供的RSA算...
    99+
    2023-10-26
    java
  • python实现rsa加密
    一 代码 import rsa key = rsa.newkeys(3000)#生成随机秘钥 privateKey = key[1]#私钥 publicKey = key[0]#公钥 message ='sanxi Now is b...
    99+
    2023-01-31
    python rsa
  • Go语言如何实现Sm2加解密
    这篇文章主要讲解了“Go语言如何实现Sm2加解密”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言如何实现Sm2加解密”吧!在 Go 语言中,可以使用 github.com/tjfoc/...
    99+
    2023-07-05
  • 用 Python 来实现 RSA 加解密
    昨天看到一篇英文文章[1],展示了如何用 Python 来实现 RSA 算法,代码的逻辑与前文一文搞懂 RSA 算法一样,不太熟悉 RSA 的朋友可以看一下一文搞懂 RSA 算法,里面对什么是 RSA,RSA 的数学原理进行了说明,并举了一...
    99+
    2023-05-14
    Python RSA 加解密
  • Go 语言中怎么实现凯撒加密
    今天就跟大家聊聊有关 Go 语言中怎么实现凯撒加密,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码清单 9-6 处理单个字符: caesar.go...
    99+
    2024-04-02
  • 怎么实现security.js RSA加密与java客户端解密
    本篇文章给大家分享的是有关怎么实现security.js RSA加密与java客户端解密,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  在通常的http协议的网站中直接提交数...
    99+
    2023-06-02
  • Vue项目怎么实现rsa加密
    这篇“Vue项目怎么实现rsa加密”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue项目怎么实现rsa加密”文章吧。安装j...
    99+
    2023-07-02
  • 怎么通过Go语言实现凯撒加密
    小编给大家分享一下怎么通过Go语言实现凯撒加密,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在 2 世纪, 发送机密消息的一个有效方法就是对每个字母进行位移, 使...
    99+
    2023-06-27
  • Go语言中怎么实现HTTPS加密协议
    Go语言中怎么实现HTTPS加密协议,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Go语言Go语言是谷歌推出的一种全新的编程语言,可以在不损失应用程序性能的情况...
    99+
    2023-06-04
  • 利用Python实现RSA加密解密方法实例
    目录前言一、安装模块二、生成密钥对三、加密四、解密五、完整代码总结前言 加密技术在数据安全存储,数据传输中发挥着重要作用,能够保护用户隐私数据安全,防止信息窃取。RSA是一种非对称加...
    99+
    2024-04-02
  • RSA如何实现C# 加密
    RSA如何实现C# 加密,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。RSA实现C# 加密首先我们来了解下什么是RSA ,它属于不对称加密,其原理就是使用一个公...
    99+
    2023-06-17
  • 使用 Go 语言实现高效的数据加密和解密
    小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《使用 Go 语言实现高效的数据加密和解密》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识...
    99+
    2024-04-04
  • c语言如何实现DES加密解密
    目录c语言实现DES加密解密C语言DES加密解密的认识以及解密出现乱码的分析Des加密Des加密模式填充方式保证加密解密的一致性 python中的des加密总结c语言实现DES加密解...
    99+
    2023-05-18
    c语言DES c语言加密解密 DES加密解密
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作