php7实现基于openssl的加密解密方法
Posted 星希望
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php7实现基于openssl的加密解密方法相关的知识,希望对你有一定的参考价值。
还需要注意的是加密字符串长度问题,如果加密字符串长度太长需要进行分段加解密,如下代码:
加密:(公匙加密,私密一般用来解密)
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
以上是关于php7实现基于openssl的加密解密方法的主要内容,如果未能解决你的问题,请参考以下文章
PHP微信开放平台---消息加解密-php7.1 使用openssl代替Mcrypt
php基于openssl相关函数的签名加密解密验证等操作技巧