php rsa加密解密使用详解


Posted in PHP onJanuary 14, 2015

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 "<br>";

print_r($pu_key);echo "\n"; echo "<br>";

echo "<hr>";

$data='php ras加密算法';

$encrypted = ""; 

$decrypted = ""; 

echo "加密的源数据:".$data."\n"; echo "<br>";

echo "private key encrypt:\n"; echo "<br>";

openssl_private_encrypt($data,$encrypted,$pi_key);//私钥加密 

$encrypted = base64_encode($encrypted);//加密后的内容通常含有特殊字符,需要编码转换下,在网络间通过url传输时要注意base64编码是否是url安全的 

echo '私钥加密后:'.$encrypted."\n"; echo "<br>";echo "<br>";

echo "public key decrypt:\n"; echo "<br>";

openssl_public_decrypt(base64_decode($encrypted),$decrypted,$pu_key);//私钥加密的内容通过公钥可用解密出来 

echo '公钥解密后:'.$decrypted."\n"; echo "<br>";

echo "<hr>";

echo "public key encrypt:\n"; echo "<br>";

openssl_public_encrypt($data,$encrypted,$pu_key);//公钥加密 

$encrypted = base64_encode($encrypted); 

echo $encrypted,"\n"; echo "<br>";

echo "private key decrypt:\n"; echo "<br>";

openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);//私钥解密 

echo $decrypted,"\n"; echo "<br>";

PHP的RSA配置常见问题

●PHP开发语言的代码示例中openssl文件夹中的3个DLL文件用法

1、如果你的系统是windows系统,且system32文件目录下没有libeay32.dll、ssleay32.dll这两个文件
那么需要拷贝这两个文件到system32文件目录。

2、如果您的php安装目录下(php\ext)中没有php_openssl.dll

那么请把php_openssl.dll放在这个文件夹中

喜欢加密解密的小伙伴一定要好好看看这篇文章,受益匪浅。。。

PHP 相关文章推荐
聊天室php&amp;mysql(二)
Oct 09 PHP
php5数字型字符串加解密代码
Apr 24 PHP
简单的php数据库操作类代码(增,删,改,查)
Apr 08 PHP
php5.3 不支持 session_register() 此函数已启用的解决方法
Nov 12 PHP
php多次include后导致全局变量global失效的解决方法
Feb 28 PHP
php自定义类fsocket模拟post或get请求的方法
Jul 31 PHP
Zend Framework教程之动作的基类Zend_Controller_Action详解
Mar 07 PHP
php $_SESSION会员登录实例分享
Jan 19 PHP
人脸识别测颜值、测脸龄、测相似度微信接口
Apr 07 PHP
使用php实现从身份证中提取生日
May 09 PHP
PHP删除数组中特定元素的两种方法
Feb 28 PHP
phpStudy vscode 搭建debug调试的教程详解
Jul 28 PHP
ThinkPHP 404页面的设置方法
Jan 14 #PHP
THINKPHP内容分页代码分享
Jan 14 #PHP
php+mysql删除指定编号员工信息的方法
Jan 14 #PHP
php实现redis数据库指定库号迁移的方法
Jan 14 #PHP
php导入excel文件到mysql数据库的方法
Jan 14 #PHP
php+mysql查询优化简单实例
Jan 13 #PHP
php5.4以下版本json不支持不转义内容中文的解决方法
Jan 13 #PHP
You might like
php 常用字符串函数总结
2008/03/15 PHP
PHP 用数组降低程序的时间复杂度
2009/12/04 PHP
WordPress判断用户是否登录的代码
2011/03/17 PHP
浅析51个PHP处理字符串的函数
2013/08/02 PHP
一个PHP二维数组排序的函数分享
2014/01/17 PHP
PHP 如何获取二维数组中某个key的集合
2014/06/03 PHP
Codeigniter检测表单post数据的方法
2015/03/21 PHP
thinkPHP分组后模板无法加载问题解决方法
2016/07/12 PHP
jQuery 表单验证扩展(三)
2010/10/20 Javascript
jQuery弹出框代码封装DialogHelper
2015/01/30 Javascript
jquery自定义表格样式
2015/11/23 Javascript
JavaScript获取当前运行脚本文件所在目录的方法
2016/02/03 Javascript
浅谈javascript alert和confirm的美化
2016/12/15 Javascript
javascript数据类型详解
2017/02/07 Javascript
[原创]SyntaxHighlighter自动识别并加载脚本语言
2017/02/07 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
深入理解node.js http模块
2018/01/24 Javascript
select获取下拉框的值 下拉框默认选中方法
2018/02/28 Javascript
JavaScript设计模式之构造器模式(生成器模式)定义与用法实例分析
2018/07/26 Javascript
微信开发之微信jssdk录音功能开发示例
2018/10/22 Javascript
[01:04:48]VGJ.S vs TNC Supermajor 败者组 BO3 第一场 6.6
2018/06/07 DOTA
极简的Python入门指引
2015/04/01 Python
python数组过滤实现方法
2015/07/27 Python
python 的列表遍历删除实现代码
2020/04/12 Python
使用pandas对两个dataframe进行join的实例
2018/06/08 Python
flask-restful使用总结
2018/12/04 Python
PyQt5下拉式复选框QComboCheckBox的实例
2019/06/25 Python
python通过txt文件批量安装依赖包的实现步骤
2019/08/13 Python
python梯度下降算法的实现
2020/02/24 Python
python实现门限回归方式
2020/02/29 Python
JupyterNotebook 输出窗口的显示效果调整实现
2020/09/22 Python
手对手的教你用canvas画一个简单的海报的方法示例
2018/12/10 HTML / CSS
举例说明类变量和实例变量的区别
2016/06/30 面试题
2014年教师工作总结
2014/11/10 职场文书
2014年法院个人工作总结
2014/12/17 职场文书
JavaScript实现复选框全选功能
2021/04/11 Javascript