php rsa加密解密執行個體,rsa加密解密執行個體_PHP教程

來源:互聯網
上載者:User

php rsa加密解密執行個體,rsa加密解密執行個體


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 "
";
print_r($pu_key);echo "\n"; echo "
";
echo "";

$data='php ras密碼編譯演算法';
$encrypted = "";
$decrypted = "";

echo "加密的來源資料:".$data."\n"; echo "
";
echo "private key encrypt:\n"; echo "
";
openssl_private_encrypt($data,$encrypted,$pi_key);//私密金鑰加密
$encrypted = base64_encode($encrypted);//加密後的內容通常含有特殊字元,需要編碼轉換下,在網路間通過url傳輸時要注意base64編碼是否是url安全的
echo '私密金鑰加密後:'.$encrypted."\n"; echo "
";echo "
";

echo "public key decrypt:\n"; echo "
";
openssl_public_decrypt(base64_decode($encrypted),$decrypted,$pu_key);//私密金鑰加密的內容通過公開金鑰可用解密出來
echo '公開金鑰解密後:'.$decrypted."\n"; echo "
";
echo "";

echo "public key encrypt:\n"; echo "
";
openssl_public_encrypt($data,$encrypted,$pu_key);//公開金鑰加密
$encrypted = base64_encode($encrypted);
echo $encrypted,"\n"; echo "
";

echo "private key decrypt:\n"; echo "
";
openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);//私密金鑰解密
echo $decrypted,"\n"; echo "
";

PHP的RSA配置常見問題:
●PHP開發語言的程式碼範例中openssl檔案夾中的3個DLL檔案用法

1、如果你的系統是windows系統,且system32檔案目錄下沒有libeay32.dll、ssleay32.dll這兩個檔案
那麼需要拷貝這兩個檔案到system32檔案目錄。

2、如果您的php安裝目錄下(php\ext)中沒有php_openssl.dll

那麼請把php_openssl.dll放在這個檔案夾中

http://www.bkjia.com/PHPjc/942279.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/942279.htmlTechArticlephp rsa加密解密執行個體,rsa加密解密執行個體 1、加密解密的第一步是產生公開金鑰、私密金鑰對,私密金鑰加密的內容能通過公開金鑰解密(反過來亦可以) 下載開...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.