go rsa加密
时间: 2023-07-08 21:23:27 浏览: 80
RSA是一种非对称加密算法,可以用于加密和解密数据。下面是在Go语言中使用RSA进行加密的示例代码:
```go
package main
import (
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/pem"
"fmt"
)
func main() {
// 生成RSA密钥对
privateKey, err := rsa.GenerateKey(rand.Reader, 2048)
if err != nil {
panic(err)
}
// 获取公钥
publicKey := &privateKey.PublicKey
// 加密的明文
plaintext := []byte("Hello, RSA!")
// 使用公钥加密明文
ciphertext, err := rsa.EncryptPKCS1v15(rand.Reader, publicKey, plaintext)
if err != nil {
panic(err)
}
// 打印加密后的密文
fmt.Printf("加密后的密文:%x\n", ciphertext)
// 使用私钥解密密文
decrypted, err := rsa.DecryptPKCS1v15(rand.Reader, privateKey, ciphertext)
if err != nil {
panic(err)
}
// 打印解密后的明文
fmt.Printf("解密后的明文:%s\n", decrypted)
}
```
在上面的示例中,我们使用rsa.GenerateKey函数生成了一个2048位的RSA密钥对,然后获取了公钥。接下来,使用rsa.EncryptPKCS1v15函数使用公钥加密了明文,并将加密后的密文打印出来。最后,使用rsa.DecryptPKCS1v15函数使用私钥解密了密文,并将解密后的明文打印出来。
阅读全文