1、加密解密的第一步是產生公開金鑰、私密金鑰對,私密金鑰加密的內容能通過公開金鑰解密(反過來亦可以)
下載開源RSA密鑰產生工具openssl(通常Linux系統都內建該程式),解壓縮至獨立的檔案夾,進入其中的bin目錄,執行以下命令:
複製代碼 代碼如下:
openssl genrsa -out rsa_private_key.pem 1024
openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt -out private_key.pem
openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
第一條命令產生原始 RSA私密金鑰檔案 rsa_private_key.pem,第二條命令將原始 RSA私密金鑰轉換為 pkcs8格式,第三條產生RSA公開金鑰 rsa_public_key.pem
從上面看出通過私密金鑰能產生對應的公開金鑰,因此我們將私密金鑰private_key.pem用在伺服器端,公開金鑰發放給android跟ios等前端
2、php中用產生的公開金鑰、私密金鑰進行加密解密,直接上代碼
複製代碼 代碼如下:
$fp=fopen("rsa/rsa_private_key.pem","r"); //你的私密金鑰檔案路徑
$private_key=fread($fp,8192);
fclose($fp);
$fp1=fopen("rsa/rsa_public_key.pem","r"); //你的公開金鑰檔案路徑
$public_key=fread($fp1,8192);
fclose($fp1);
//echo $private_key;
$pi_key=openssl_pkey_get_private($private_key);//這個函數可用來判斷私密金鑰是否是可用的,可用返回資源id Resource id
$pu_key=openssl_pkey_get_public($public_key );//這個函數可用來判斷公開金鑰是否是可用的
print_r($pi_key);echo "\n"; echo "<br>";
print_r($pu_key);echo "\n"; echo "<br>";
echo "<hr>";
$data='php ras密碼編譯演算法';
$encrypted = "";
$decrypted = "";
echo "加密的來源資料:".$data."\n"; echo "<br>";
echo "private key encrypt:\n"; echo "<br>";
openssl_private_encrypt($data,$encrypted,$pi_key);//私密金鑰加密
$encrypted = base64_encode($encrypted);//加密後的內容通常含有特殊字元,需要編碼轉換下,在網路間通過url傳輸時要注意base64編碼是否是url安全的
echo '私密金鑰加密後:'.$encrypted."\n"; echo "<br>";echo "<br>";
echo "public key decrypt:\n"; echo "<br>";
openssl_public_decrypt(base64_decode($encrypted),$decrypted,$pu_key);//私密金鑰加密的內容通過公開金鑰可用解密出來
echo '公開金鑰解密後:'.$decrypted."\n"; echo "<br>";
echo "<hr>";
echo "public key encrypt:\n"; echo "<br>";
openssl_public_encrypt($data,$encrypted,$pu_key);//公開金鑰加密
$encrypted = base64_encode($encrypted);
echo $encrypted,"\n"; echo "<br>";
echo "private key decrypt:\n"; echo "<br>";
openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);//私密金鑰解密
echo $decrypted,"\n"; echo "<br>";
PHP的RSA配置常見問題:
●PHP開發語言的程式碼範例中openssl檔案夾中的3個DLL檔案用法
1、如果你的系統是windows系統,且system32檔案目錄下沒有libeay32.dll、ssleay32.dll這兩個檔案
那麼需要拷貝這兩個檔案到system32檔案目錄。
2、如果您的php安裝目錄下(php\ext)中沒有php_openssl.dll
那麼請把php_openssl.dll放在這個檔案夾中
喜歡加密解密的小夥伴一定要好好看看這篇文章,受益匪淺。。。