php pki加密技術(shù)(openssl)詳解
更新時間:2013年07月01日 10:30:20 作者:
本篇文章是對php中的pki加密技術(shù)(openssl)進行了詳細的分析介紹,需要的朋友參考下
復制代碼 代碼如下:
<?php
//pki加密
//使用pki加密需要開啟 openssl擴展
//php.ini extension = php_openssl.dll擴展
/*pki模式是
* 公鑰加密,私鑰解密;
* 私鑰加密,公鑰解密;
*/
//私鑰加密,公鑰解密
//客戶端
//$data數(shù)據(jù)
$data = 'abcd';
//獲取私鑰 $priv_key_id
$priv_key_id = openssl_get_privatekey(file_get_contents('99bill-rsa.pem', r));
//獲取公鑰 $pub_key_id
$pub_key_id = openssl_get_publickey(file_get_contents('99bill-rsa.cer', r));
//$data首選通過SHA1哈希加密,然后通過$priv_key_id私鑰加密,生成簽名$signature
//$signature就是加密過的簽名
//openssl_sign()加密函數(shù),至于它的解密方法我不知道??????????????????????
openssl_sign($data, $signature, $priv_key_id, OPENSSL_ALGO_SHA1);
//還有兩種加密函數(shù),而且這兩種加密函數(shù)有解密方法,知道
//第一種:私鑰加密,公鑰解密
//$data要加密的數(shù)據(jù),$crypted是加密生成的數(shù)據(jù),$decrypted是解密生成的數(shù)據(jù); $data與$decrypted值相同
//通過$priv_key_id私鑰加密,生成$crypted;
openssl_private_encrypt($data, $crypted, $priv_key_id);
echo $crypted;
//通過$pub_key_id公鑰解密,生成$decrypted
openssl_public_decrypt($crypted, $decrypted , $pub_key_id);
//第二種:公鑰加密,私鑰解密
//$data要加密的數(shù)據(jù),$crypted是加密生成的數(shù)據(jù),$decrypted是解密生成的數(shù)據(jù); $data與$decrypted值相同
//通過$pub_key_id公鑰加密,生成$crypted;
openssl_public_encrypt($data, $crypted, $pub_key_id);
//通過$priv_key_id私鑰解密,生成$decrypted
openssl_private_decrypt($crypted, $decrypted, $priv_key_id);
//注意事項,我這邊的獲取公鑰與私鑰的文件是不對應的
//正常情況,獲取公鑰與私鑰文件是一一對應的,這里我使用快錢的。
//快錢給了私鑰生成文件,對應的公鑰生成文件在快錢那邊
//快錢給了公鑰生成文件,對應的私鑰生成文件在快錢那邊
//也就是缺少了一個公鑰生成文件和一個私鑰生成文件
//我始終沒找到一個一一對應的私鑰、公鑰生成文件,如果你找的了發(fā)我一份,謝謝。
// openssl_verify()方法驗證簽名是否正確(私鑰加密生成的數(shù)據(jù)返回來,用對應的公鑰驗證),只有這一種情況。
// $signature公鑰加密生成的數(shù)據(jù),$data原始數(shù)據(jù),成功返回1,失敗返回0,錯誤返回-1
// $pub_key_id公鑰
openssl_verify($data, $signature, $pub_key_id);
//從內(nèi)存中釋放私鑰或公鑰
openssl_free_key($priv_key_id);
openssl_free_key($pub_key_id);
生成私鑰與公鑰
genrsa -out private-rsa.pem
rsa -in private-rsa.pem -pubout -out pubic-rsa.cer
您可能感興趣的文章:
- Windows安裝配置C/C++(VS2017)OpenSSL開發(fā)環(huán)境配置教程
- php開啟openssl的方法
- Linux下Nginx安裝的方法(pcre和openssl)
- PHP 7.1中利用OpenSSL代替Mcrypt加解密的方法詳解
- php實現(xiàn)基于openssl的加密解密方法
- php7安裝openssl擴展方法
- C語言使用openSSL庫AES模塊實現(xiàn)加密功能詳解
- 詳解Linux(centos7)下安裝OpenSSL安裝圖文方法
- 不重新編譯PHP為php增加openssl模塊的方法
- linux openssl基礎介紹
- 一個檢測OpenSSL心臟出血漏洞的Python腳本分享
- php基于openssl的rsa加密解密示例
- 解析php php_openssl.dll的作用
- PHP的openssl加密擴展使用小結(jié)(推薦)
- C語言使用openSSL庫DES模塊實現(xiàn)加密功能詳解
- 使用openssl 生成免費證書的方法步驟
- Windows安裝Openssl并使用Openss生成公鑰私鑰
相關(guān)文章
PHP中數(shù)組轉(zhuǎn)換為SimpleXML教程
在本篇文章中我們給大家總結(jié)了一篇關(guān)于PHP中數(shù)組轉(zhuǎn)換為SimpleXML教程內(nèi)容,有需要的朋友們跟著學習參考下。2019-01-01zend Framework中的Layout(模塊化得布局)詳解
本篇文章是對zend Framework中的Layout(模塊化得布局)進行了詳細的分析介紹,需要的朋友參考下2013-06-06關(guān)于ob_get_contents(),ob_end_clean(),ob_start(),的具體用法詳解
本篇文章是對ob_get_contents(),ob_end_clean(),ob_start(),的具體用法進行了詳細的分析介紹,需要的朋友參考下2013-06-06Ubuntu中搭建Nginx、PHP環(huán)境最簡單的方法
這篇文章主要介紹了Ubuntu中搭建Nginx、PHP環(huán)境最簡單的方法,本文講解的是使用apt-get工具安裝Nginx、PHP環(huán)境,并講解了基本配置,需要的朋友可以參考下2015-03-03