生成RSA公钥和私钥
首先需要电脑安装openssl,这个搜一下安装就行了。
然后运行命令行输入命令:
openssl genrsa -out rsa_private_key.pem 1024
回车,可以看到命令行执行的文件夹多了一个rsa_private_key.pem私钥文件
然后执行生成公钥命令:
openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
回车,可以看到命令行执行的文件夹多了一个rsa_public_key.pem公钥文件
PKCS#1格式私钥转换成PKCS#8格式私钥(一般JAVA用的都是PKCS#8格式私钥)
openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt
回车,可以看到命令行打印出了PKCS#8格式的私钥,右键复制就行了。
如何区分PKCS#1和PKCS#8格式的密钥?
用记事本开打密钥文件看看
以-----BEGIN RSA PRIVATE KEY-----开头
以-----END RSA PRIVATE KEY-----结束
的就是PKCS#1格式
以-----BEGIN PRIVATE KEY-----开头
以-----END PRIVATE KEY-----结束
的就是PKCS#8格式
最后附上pyhton和java语言实现RSA和AES加密的文章:
python实现RSA与AES混合加密
java实现RSA与AES混合加密
python,java跨语言RSA+AES混合加密解密以及踩过的那些坑