centos生成公匙私匙:
openssl genrsa -out private_key.pem 2048
openssl rsa -inform PEM -text -noout < private_key.pem
openssl rsa -inform PEM -modulus -noout < private_key.pem

获取公匙,私匙获取cat private_key.pem


如下JS前端代码加密需要使用http://www.ohdave.com/rsa/中提供的三个JS文件
        <script src="/js/rsa/Barrett.js"></script>
        <script src="/js/rsa/BigInt.js"></script>
        <script src="/js/rsa/RSA.js"></script>


function encryptfunc(str)
{
    setMaxDigits(259); 
    var publickey = '公匙';
    var key = new RSAKeyPair("10001", '10001', publickey, 2048); 
    str = encryptedString(key, str, RSAAPP.PKCS1Padding, RSAAPP.RawEncoding);
    return window.btoa(str);
}

前端加密如下:
var name = encryptfunc(encodeURIComponent($('input#name').val()));

encodeURIComponent是为了有中文的时候



后端解密:


function DecryptRsa($str)
{
$private_key =openssl_pkey_get_private('-----BEGIN RSA PRIVATE KEY-----
私匙
-----END RSA PRIVATE KEY-----');
$ciphertext = $str; // 获取POST提交密文
// ...convert to binary.
$bin_ciphertext = base64_decode($ciphertext); // 对密文base64解码
openssl_private_decrypt($bin_ciphertext, $plaintext, $private_key, OPENSSL_PKCS1_PADDING) // $plaintext为解密明文,解密函数为PHP自带函数
    or die("openssl_private_decrypt failed.");
return $plaintext;
}


注意在vscode里面编辑的时候私匙前面不能有缩进,不然会报错
$value = DecryptRsa($value);