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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM