1.生成秘钥对
# openssl genrsa -out rsa_private_key.pem 2048 //生成私钥
# openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform pem -nocrypt -out rsa_private_pkcs8_key.pem //生成PKCS8私钥
# openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem //生成PKCS8公钥
# openssl rsa -in rsa_private_key.pem -RSAPublicKey_out -out rsa_public_key.pem //生成PKCS1公钥
# openssl rsa -pubin -inform PEM -modulus -noout < rsa_public_key.pem //生成普通js公钥
备注:
PKCS1私钥
-----BEGIN RSA PRIVATE KEY-----
-----END RSA PRIVATE KEY-----
PKCS1公钥
-----BEGIN RSA PUBLIC KEY-----
-----END RSA PUBLIC KEY-----
PKCS8私钥
-----BEGIN PRIVATE KEY-----
----- PRIVATE KEY-----
PKCS8公钥
-----BEGIN PUBLIC KEY-----
-----END PUBLIC KEY-----
2.NodeRsa
let NodeRsa = require('node-rsa')
let key = new NodeRsa(rsa_public_pkcs1_key)
let encrypted = key.encrypt('hello world', 'base64')
console.dir(encrypted)
3.php
openssl_private_decrypt(base64_decode($data), $decrypted, $this->private_key , OPENSSL_PKCS1_OAEP_PADDING);
var_dump($decrypted);