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对称加密-AES

非对称加密openssl协议在php7实践

php基于openssl相关函数的签名加密解密验证等操作技巧

php7使用openssl_encrypt函数进行AES加密

如何使用之前使用 mcrypt 加密的 OpenSSL 解密字符串?