php7实现基于openssl的加密解密方法
2024-10-20 08:27:37
还需要注意的是加密字符串长度问题,如果加密字符串长度太长需要进行分段加解密,如下代码:
加密:(公匙加密,私密一般用来解密)
function encrypt($originalData){
$publicKeyFilePath = '/www/ceshi/rsa_public_key.pem';
extension_loaded('openssl') or die('php需要openssl扩展支持');
file_exists($publicKeyFilePath) or die('公钥的文件路径不正确');
$publicKey = openssl_pkey_get_public(file_get_contents($publicKeyFilePath));
$publicKey or die('公钥不可用');
$crypto = '';
foreach (str_split($originalData, 117) as $chunk) {
$encryptData = '';
if(openssl_public_encrypt($chunk, $encryptData, $publicKey)){
$crypto .= $encryptData;
}else{
die('加密失败');
}
}
return base64_encode($crypto);
}
解密:
function decrypt($encryptData){
$privateKeyFilePath = '/www/ceshi/rsa_private_key.pem';
extension_loaded('openssl') or die('php需要openssl扩展支持');
file_exists($privateKeyFilePath) or die('密钥的文件路径不正确');
$privateKey = openssl_pkey_get_private(file_get_contents($privateKeyFilePath));
$privateKey or die('密钥不可用');
$decryptData = '';
$crypto = '';
foreach (str_split(base64_decode($encryptData), 128) as $chunk) {
if(openssl_private_decrypt($chunk, $decryptData, $privateKey)){
$crypto .= $decryptData;
}else{
die('解密失败');
} }
return $crypto;
}
调用:
$aa = encrypt('aa');
$bb = decrypt($aa);
var_dump($bb);
输出的结果为:aa
最新文章
- css使absolute相对于父容器进行定位而不是以body(为什么绝对定位(absolute)的父级元素必须是相对定位(relative))
- ble示例代码
- LVM增大和减小ext4、xfs分区
- 键盘unicode值对照表
- 转:C#精髓 第四讲 GridView 72般绝技
- css中float left与float right的使用说明
- C:移位运算符
- firefox 的event事件处理
- python的按位运算
- POJ 2352 &;amp;&;amp; HDU 1541 Stars (树状数组)
- jenkins-APP打包页面展示二维码
- thinkphp 中英文网站详解
- Python3学习之路~7.1 静态方法、类方法、属性方法
- 深挖JDK动态代理(二):JDK动态生成后的字节码分析
- shell 按序删除文件
- 初学c# -- 开始学directx
- 红黑树深入剖析及Java实现
- 7种html5css3网页图片展示特效代码
- TCP 三次握手理解和过程
- vs2010中自动给函数或者类加上注释宏模板