105 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
| package rsa
 | |
| 
 | |
| import (
 | |
| 	"crypto/rand"
 | |
| 	"crypto/rsa"
 | |
| 	"crypto/sha256"
 | |
| 	"crypto/x509"
 | |
| 	"encoding/base64"
 | |
| 	"encoding/pem"
 | |
| 	"errors"
 | |
| )
 | |
| 
 | |
| // RSA生成公私密钥
 | |
| func RSAGenKey(bits int) (pub string, pri string, ok bool) {
 | |
| 	if bits%1024 != 0 {
 | |
| 		return
 | |
| 	}
 | |
| 	privateKey, err := rsa.GenerateKey(rand.Reader, bits)
 | |
| 	if err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	privateStream := x509.MarshalPKCS1PrivateKey(privateKey)
 | |
| 	block1 := pem.Block{Type: "private key", Bytes: privateStream}
 | |
| 	pri = string(pem.EncodeToMemory(&block1))
 | |
| 	publicKey := privateKey.PublicKey
 | |
| 	publicStream, err := x509.MarshalPKIXPublicKey(&publicKey)
 | |
| 	if err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	block2 := pem.Block{Type: "public key", Bytes: publicStream}
 | |
| 	pub = string(pem.EncodeToMemory(&block2))
 | |
| 	ok = true
 | |
| 	return
 | |
| }
 | |
| 
 | |
| // RSA加密
 | |
| func Encrypt(pubkey, data string) string {
 | |
| 	block, _ := pem.Decode([]byte(pubkey))
 | |
| 	if block == nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	pubInterface, err := x509.ParsePKIXPublicKey(block.Bytes)
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	pub := pubInterface.(*rsa.PublicKey)
 | |
| 	res, err := rsa.EncryptPKCS1v15(rand.Reader, pub, []byte(data))
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	return base64.StdEncoding.EncodeToString(res)
 | |
| }
 | |
| func EncryptWithPublicKey(publicKeyPEM string, plaintext string) (string, error) {
 | |
| 	// 解码PEM格式的公钥
 | |
| 	// block, _ := pem.Decode([]byte(publicKeyPEM))
 | |
| 	// if block == nil {
 | |
| 	// 	return "", nil
 | |
| 	// }
 | |
| 	pubKey := []byte(publicKeyPEM)
 | |
| 	// 解析公钥
 | |
| 	pub, err := x509.ParsePKIXPublicKey(pubKey)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 	rsaPub, ok := pub.(*rsa.PublicKey)
 | |
| 	if !ok {
 | |
| 		return "", errors.New("not a valid RSA public key")
 | |
| 	}
 | |
| 	// 将字符串转换为字节数组
 | |
| 	message := []byte(plaintext)
 | |
| 	// 使用OAEP填充和SHA-256哈希函数进行加密
 | |
| 	label := []byte("") // OAEP label, 可以根据需要设置
 | |
| 	hash := sha256.New()
 | |
| 	ciphertext, err := rsa.EncryptOAEP(hash, rand.Reader, rsaPub, message, label)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 	// 将密文编码为base64字符串
 | |
| 	return base64.StdEncoding.EncodeToString(ciphertext), nil
 | |
| }
 | |
| 
 | |
| // RSA解密
 | |
| func Decrypt(prikey, data string) string {
 | |
| 	if len(data) < 4 {
 | |
| 		return ""
 | |
| 	}
 | |
| 	ciphertext, err := base64.StdEncoding.DecodeString(data)
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	block, _ := pem.Decode([]byte(prikey))
 | |
| 	if block == nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	priv, err := x509.ParsePKCS1PrivateKey(block.Bytes)
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	text, err := rsa.DecryptPKCS1v15(rand.Reader, priv, ciphertext)
 | |
| 	if err != nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	return string(text)
 | |
| }
 |