RSA加减密 前端JS加密,后端PHP解密

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);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nanj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值