PHP封装的非对称加密RSA算法示例


Posted in PHP onMay 28, 2018

本文实例讲述了PHP封装的非对称加密RSA算法。分享给大家供大家参考,具体如下:

将php的openssl扩展中的非对称加密函数封装成一个Rsa类。

需要注意的是,在windows上,需要打开openssl的配置文件,请参照官方的openssl扩展安装文档。

在windows上安装openssl扩展

1、将php路径下的两个库文件libeay32.dll和ssleay32.dll复制到操作system32下

2、配置openssl配置文件的位置,在php的路径下,有文件extras/openssl/openssl.cnf,添加环境变量OPENSSL_CONF指向这个文件的全路径。如何添加环境变量请google搜索之。

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

使用的demo:

//====================demo=======================
//以下是一个简单的测试demo,如果不需要请删除
$rsa = new Rsa('sslkey'); //sslkey为存放密钥的路径,将已有的密钥文件复制到该路径下,公钥名称为pub.key,私钥名称为priv.key
$rsa->createKey(); //创建一对密钥,如果密钥对已经存在,不需调用
//私钥加密,公钥解密
echo 'source:三水点靠木<br />';
$pre = $rsa->privEncrypt('三水点靠木');
echo 'private encrypted:<br />' . $pre . '<br />';
$pud = $rsa->pubDecrypt($pre);
echo 'public decrypted:' . $pud . '<br />';
//公钥加密,私钥解密
echo 'source:干IT的<br />';
$pue = $rsa->pubEncrypt('干IT的');
echo 'public encrypt:<br />' . $pue . '<br />';
$prd = $rsa->privDecrypt($pue);
echo 'private decrypt:' . $prd;
//========================demo======================

本示例在windows7、php 5.2.14、openssl 0.98下开发

<?php
/**
 * 使用openssl实现非对称加密
 *
 */
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);
    }
}
PHP 相关文章推荐
MySql 按时间段查询数据方法(实例说明)
Nov 02 PHP
在PHP中养成7个面向对象的好习惯
Jul 17 PHP
ThinkPHP多表联合查询的常用方法
Mar 24 PHP
php中ftp_chdir与ftp_cdup函数用法
Nov 18 PHP
PHP调用wsdl文件类型的接口代码分享
Nov 19 PHP
php使用cookie显示用户上次访问网站日期的方法
Jan 26 PHP
ECSHOP完美解决Deprecated: preg_replace()报错的问题
May 17 PHP
PHP实现将MySQL重复ID二维数组重组为三维数组的方法
Aug 01 PHP
Laravel 中使用 Vue.js 实现基于 Ajax 的表单提交错误验证操作
Jun 30 PHP
微信接口生成带参数的二维码
Jul 31 PHP
PHP封装类似thinkphp连贯操作数据库Db类与简单应用示例
May 08 PHP
php使用gearman进行任务分发操作实例详解
Feb 26 PHP
thinkPHP3.2.3结合Laypage实现的分页功能示例
May 28 #PHP
Windows下wamp php单元测试工具PHPUnit安装及生成日志文件配置方法
May 28 #PHP
PHP测试框架PHPUnit组织测试操作示例
May 28 #PHP
php empty 函数判断结果为空但实际值却为非空的原因解析
May 28 #PHP
PHP排序二叉树基本功能实现方法示例
May 26 #PHP
Thinkphp5+uploadify实现的文件上传功能示例
May 26 #PHP
PHP ADODB实现事务处理功能示例
May 25 #PHP
You might like
php下连接ftp实现文件的上传、下载、删除文件实例代码
2010/06/03 PHP
THINKPHP项目开发中的日志记录实例分析
2014/12/01 PHP
php使用sql server验证连接数据库的方法
2014/12/25 PHP
关于php 高并发解决的一点思路
2017/04/16 PHP
Laravel5.1框架注册中间件的三种场景详解
2019/07/09 PHP
JavaScript中继承的一些示例方法与属性参考
2010/08/07 Javascript
基于jquery的不规则矩形的排列实现代码
2012/04/16 Javascript
表格单元格交错着色实现思路及代码
2013/04/01 Javascript
JavaScript中对象属性的添加和删除示例
2014/05/12 Javascript
Javascript动画的实现原理浅析
2015/03/02 Javascript
JQuery 获取Dom元素的实例讲解
2017/07/08 jQuery
微信小程序实现即时通信聊天功能的实例代码
2018/08/17 Javascript
详解为生产环境编译Angular2应用的方法
2018/12/10 Javascript
JQuery获取元素尺寸、位置及页面滚动事件应用示例
2019/05/14 jQuery
python简单实现基数排序算法
2015/05/16 Python
Python中unittest模块做UT(单元测试)使用实例
2015/06/12 Python
Python与Java间Socket通信实例代码
2017/03/06 Python
python中如何使用正则表达式的非贪婪模式示例
2017/10/09 Python
Django之无名分组和有名分组的实现
2019/04/16 Python
如何在python中写hive脚本
2019/11/08 Python
Python使用turtle库绘制小猪佩奇(实例代码)
2020/01/16 Python
python 使用cx-freeze打包程序的实现
2020/03/14 Python
Python虚拟环境的创建和包下载过程分析
2020/06/19 Python
Python从文件中读取数据的方法步骤
2020/11/18 Python
Python的scikit-image模块实例讲解
2020/12/30 Python
纯CSS3实现表单验证效果(非常不错)
2017/01/18 HTML / CSS
会计学应届毕业生推荐信
2013/11/04 职场文书
制药工程专业个人求职自荐信
2014/01/25 职场文书
运动会开幕式邀请函
2014/02/03 职场文书
民政局离婚协议书范本
2014/10/20 职场文书
大学生党员个人总结
2015/02/13 职场文书
四风之害观后感
2015/06/09 职场文书
大学生读书笔记大全
2015/07/01 职场文书
关于元旦的广播稿2016
2015/12/17 职场文书
Python编程中Python与GIL互斥锁关系作用分析
2021/09/15 Python
php双向队列实例讲解
2021/11/17 PHP