日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > php >内容正文

php

php封装一个加密算法,PHP封装的非对称加密RSA算法示例

發(fā)布時間:2024/1/23 php 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php封装一个加密算法,PHP封装的非对称加密RSA算法示例 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本文實例講述了PHP封裝的非對稱加密RSA算法。分享給大家供大家參考,具體如下:

將php的openssl擴展中的非對稱加密函數(shù)封裝成一個Rsa類。

需要注意的是,在windows上,需要打開openssl的配置文件,請參照官方的openssl擴展安裝文檔。

在windows上安裝openssl擴展

1、將php路徑下的兩個庫文件libeay32.dll和ssleay32.dll復(fù)制到操作system32下

2、配置openssl配置文件的位置,在php的路徑下,有文件extras/openssl/openssl.cnf,添加環(huán)境變量OPENSSL_CONF指向這個文件的全路徑。如何添加環(huán)境變量請google搜索之。

3、在php.ini里添加一行extension=php_openssl.dll

使用的demo:

//====================demo=======================

//以下是一個簡單的測試demo,如果不需要請刪除

$rsa = new Rsa('sslkey'); //sslkey為存放密鑰的路徑,將已有的密鑰文件復(fù)制到該路徑下,公鑰名稱為pub.key,私鑰名稱為priv.key

$rsa->createKey(); //創(chuàng)建一對密鑰,如果密鑰對已經(jīng)存在,不需調(diào)用

//私鑰加密,公鑰解密

echo 'source:腳本之家
';

$pre = $rsa->privEncrypt('腳本之家');

echo 'private encrypted:
' . $pre . '
';

$pud = $rsa->pubDecrypt($pre);

echo 'public decrypted:' . $pud . '
';

//公鑰加密,私鑰解密

echo 'source:干IT的
';

$pue = $rsa->pubEncrypt('干IT的');

echo 'public encrypt:
' . $pue . '
';

$prd = $rsa->privDecrypt($pue);

echo 'private decrypt:' . $prd;

//========================demo======================

本示例在windows7、php 5.2.14、openssl 0.98下開發(fā)

/**

* 使用openssl實現(xiàn)非對稱加密

*

*/

class Rsa

{

/**

* private key

*/

private $_privKey;

/**

* public key

*/

private $_pubKey;

/**

* the keys saving path

*/

private $_keyPath;

/**

* the construtor,the param $path is the keys saving path

*/

public function __construct($path)

{

if(empty($path) || !is_dir($path)){

throw new Exception('Must set the keys save path');

}

$this->_keyPath = $path;

}

/**

* create the key pair,save the key to $this->_keyPath

*/

public function createKey()

{

$r = openssl_pkey_new();

openssl_pkey_export($r, $privKey);

file_put_contents($this->_keyPath . DIRECTORY_SEPARATOR . 'priv.key', $privKey);

$this->_privKey = openssl_pkey_get_private($privKey);

$rp = openssl_pkey_get_details($r);

$pubKey = $rp['key'];

file_put_contents($this->_keyPath . DIRECTORY_SEPARATOR . 'pub.key', $pubKey);

$this->_pubKey = openssl_pkey_get_public($pubKey);

}

/**

* setup the private key

*/

public function setupPrivKey()

{

if(is_resource($this->_privKey)){

return true;

}

$file = $this->_keyPath . DIRECTORY_SEPARATOR . 'priv.key';

$prk = file_get_contents($file);

$this->_privKey = openssl_pkey_get_private($prk);

return true;

}

/**

* setup the public key

*/

public function setupPubKey()

{

if(is_resource($this->_pubKey)){

return true;

}

$file = $this->_keyPath . DIRECTORY_SEPARATOR . 'pub.key';

$puk = file_get_contents($file);

$this->_pubKey = openssl_pkey_get_public($puk);

return true;

}

/**

* encrypt with the private key

*/

public function privEncrypt($data)

{

if(!is_string($data)){

return null;

}

$this->setupPrivKey();

$r = openssl_private_encrypt($data, $encrypted, $this->_privKey);

if($r){

return base64_encode($encrypted);

}

return null;

}

/**

* decrypt with the private key

*/

public function privDecrypt($encrypted)

{

if(!is_string($encrypted)){

return null;

}

$this->setupPrivKey();

$encrypted = base64_decode($encrypted);

$r = openssl_private_decrypt($encrypted, $decrypted, $this->_privKey);

if($r){

return $decrypted;

}

return null;

}

/**

* encrypt with public key

*/

public function pubEncrypt($data)

{

if(!is_string($data)){

return null;

}

$this->setupPubKey();

$r = openssl_public_encrypt($data, $encrypted, $this->_pubKey);

if($r){

return base64_encode($encrypted);

}

return null;

}

/**

* decrypt with the public key

*/

public function pubDecrypt($crypted)

{

if(!is_string($crypted)){

return null;

}

$this->setupPubKey();

$crypted = base64_decode($crypted);

$r = openssl_public_decrypt($crypted, $decrypted, $this->_pubKey);

if($r){

return $decrypted;

}

return null;

}

public function __destruct()

{

@ fclose($this->_privKey);

@ fclose($this->_pubKey);

}

}

PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:http://tools.jb51.net/password/hash_md5_sha

希望本文所述對大家PHP程序設(shè)計有所幫助。

總結(jié)

以上是生活随笔為你收集整理的php封装一个加密算法,PHP封装的非对称加密RSA算法示例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。