php ras demo,封装php的非对称加密RSA

/**

* 使用openssl实现非对称加密

*

* @author

*/

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()

{

$configargs = array('digest_alg' => 'sha1',

'private_key_type' => OPENSSL_KEYTYPE_RSA,

'private_key_bits' => 512,

"config" => "E:/xampp/php/extras/openssl/openssl.cnf"

);

$r = openssl_pkey_new($configargs);

openssl_pkey_export($r, $privKey,null,$configargs);

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);

}

}

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

//以下是一个简单的测试demo,如果不需要请删除

$rsa = new Rsa('ssl-key');

$rsa->createKey(); //创建一对密钥,如果密钥对已经存在,不需调用

//私钥加密,公钥解密

echo 'source:就将计就计
';

$pre = $rsa->privEncrypt('就将计就计');

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

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

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

//公钥加密,私钥解密

echo 'source:干反方向
';

$pue = $rsa->pubEncrypt('干反方向');

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

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

echo 'private decrypt:' . $prd;

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

//特别注意:没有openssl.cnf配置,在创建 public/private key 的时候会出现类似以下的问题

//Warning: openssl_pkey_export() [function.openssl-pkey-export]: cannot get key from parameter,

//或者openssl_pkey_export里的私钥生成不了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值