RSA加减密 前端JS加密,后端PHP解密
2021-07-29 17:23:07
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);
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);