shuipf / phprsa
这是一个PHP的RSA算法
1.0.0
2018-06-14 08:25 UTC
Requires
- php: >=5.3.0
This package is auto-updated.
Last update: 2025-02-16 21:05:16 UTC
README
php使用rsa算法
安装
composer require shuipf/phprsa
示例
$options = [ 'private_key' => '-----BEGIN RSA PRIVATE KEY----- MIICXQIBAAKBgQC6l1VcRSMuF6DTV0gdCr0oeRgzURCnrwu9zB91lMZ44oaQtBQk wmBoaIibzM0on5B8mXxXlEzhyOoj2Ylaskh3quuYl2lU5VvkqBLJYZSFlJs9ByZQ G5+YhMkwRwzaCw67FJsD/bJTpARLAXJVBKdCj4Fro2y+w/5w6esf7h09CQIDAQAB AoGBAJ/ZJXd2gzzpYQ2sqEq4+HPDycesmugMPbLLO+gvHBhTd5RfsSIMoyrO4rkW KmuyxsT3eF5O3c5PoMY1hkX8lbb4XSCkXDm/Zwfv9b+3J7gv0Hrl+q2hYmtIqdMB vnLS5PtM3SB6kzuCZJk1NuedewEL7/4Rpxyaw0Jjo+ixBkJBAkEA3ppWbYd6TEEo wCwgITvNeTdvm/0GVEKNqgOcqdnVNKz8/lzMLMyaHG8Dq8fMPzKRhCY4EBCTi+P2 mczWCcyT/wJBANaV3kf0P0vXXOLgridJ/DZ9XGGm0+apOQ7D/ci/N9O4RpPoEerH kQOImsAuKPYINr1cwsd/2hWYoWKxdMRdjvcCQDDd6slCq3tf9oUxaqBBE5tfqxWw VxpaPeUrw9GZq29T5nokfwH6rH4/dKvaQaFCBaXgCgCk0u8rzS/4QqiGC5sCQGqD BUxN7kUk5xQuVgNmc+xQGVTXTAMIKCwuGIBWec17gHzWCl6xJEfOvJF72BUXSqR/ sKb5zTQ/CIxGbSEzF00CQQCcphnvT/zc7kMSCl5LhDA4Hf8TSoV5zrry8nemEhi8 P6IPDOuyfn699kprL2UjknpdRFJ1/gDRTLALP6KJrmfy -----END RSA PRIVATE KEY-----', 'public_key' => '-----BEGIN PUBLIC KEY----- MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC6l1VcRSMuF6DTV0gdCr0oeRgz URCnrwu9zB91lMZ44oaQtBQkwmBoaIibzM0on5B8mXxXlEzhyOoj2Ylaskh3quuY l2lU5VvkqBLJYZSFlJs9ByZQG5+YhMkwRwzaCw67FJsD/bJTpARLAXJVBKdCj4Fr o2y+w/5w6esf7h09CQIDAQAB -----END PUBLIC KEY-----', ]; $rsa = \shuipf\phprsa\RsaCrypt::getInstance($options);//实例化单例类 if ($_POST){ //web端公钥加密的内容 $pu_pwd = $_POST["pu_pwd"]; $decrypted = $rsa->decodePublicEncode($pu_pwd); if ($decrypted){ echo '私钥解密公钥加密的内容:'.$decrypted; }else{ echo "私钥解密失败"; } exit; } $str = md5('123456'); echo '原始数据:'.$str . "\n"; //私钥加密 $data = $rsa->privateKeyEncode($str); if (!empty($data)){ echo '私钥加密:'.$data . "\n"; }else{ echo '私钥加密失败 <br><br><br>'; } //公钥解密 $decode = $rsa->decodePrivateEncode($data); if (!empty($decode)){ echo '公钥解密:'.$decode . "\n"; }else{ echo "公钥解密失败 \n"; } $pdata = $rsa->publicKeyEncode($str); if ($pdata){ echo '公钥加密:'.$pdata . "\n"; }else{ echo "公钥加密失败 \n"; } //私钥解密 $pdecode = $rsa->decodePublicEncode($pdata); if ($pdecode){ echo '私钥解密:'.$pdecode . "\n"; }else{ echo "私钥解密失败 \n"; }
#需要原型工具:
OpenSSL下载地址:http://slproweb.com/products/Win32OpenSSL.html
-
安装OpenSSL
- 随意安装到哪里
-
点击OpenSLL的bin目录下的 openssl.exe 进行私钥和公钥的生成
- 生成私钥
- genrsa -out rsa_private_key.pem 1024
- 生成公钥
- rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
-
将生产的私钥、公钥拷贝到你的PHP项目中
-
开启PHP的OpenSSL扩展
- 将php.ini中的extension=php_openssl.dll开启(去掉;)