PHP進行AES/ECB/PKCS7 padding加密的例子(openssl)


上一篇文章講到利用mcrypt對數據進行aes加密的方法,但是不支持php7.1.x版本,今天在stackoverflow上看到同樣的問題,是使用openssl函數的處理方法,點擊下面的鏈接stackoverflow查看問題,根據上面的問題整理出了一個簡單的加密類,經測試完全符合業務需求,現在寫出來,希望對以后的工作會有幫助。

利用openssl加密更簡單,而且支持php7.1.x版本,基本可以用於所有版本的php程序。

<?php

class OpenSSLAES
{
    /**
     * var string $method 加解密方法,可通過openssl_get_cipher_methods()獲得
     */
    protected $method;

    /**
     * var string $secret_key 加解密的密鑰
     */
    protected $secret_key;

    /**
     * var string $iv 加解密的向量,有些方法需要設置比如CBC
     */
    protected $iv;

    /**
     * var string $options (不知道怎么解釋,目前設置為0沒什么問題)
     */
    protected $options; 

    /**
     * 構造函數
     *
     * @param string $key 密鑰
     * @param string $method 加密方式
     * @param string $iv iv向量
     * @param mixed $options 還不是很清楚 
     *
     */
    public function __construct($key, $method = 'AES-128-ECB', $iv = '', $options = 0)
    {
        // key是必須要設置的
        $this->secret_key = isset($key) ? $key : exit('key為必須項');

        $this->method = $method;

        $this->iv = $iv;

        $this->options = $options;
    }

    /**
     * 加密方法,對數據進行加密,返回加密后的數據
     *
     * @param string $data 要加密的數據
     * 
     * @return string 
     *
     */
    public function encrypt($data)
    {
        return openssl_encrypt($data, $this->method, $this->secret_key, $this->options, $this->iv);
    }

    /**
     * 解密方法,對數據進行解密,返回解密后的數據
     *
     * @param string $data 要解密的數據
     * 
     * @return string 
     *
     */
    public function decrypt($data)
    {
        return openssl_decrypt($data, $this->method, $this->secret_key, $this->options, $this->iv);
    }
}

$aes = new OpenSSLAES('12345678');

$encrypted = $aes->encrypt('憑欄知瀟雨');
// KSGYvH0GOzQULoLouXqPJA==
echo '要加密的字符串:憑欄知瀟雨<br>加密后的字符串:', $encrypted, '<hr>';

$decrypted = $aes->decrypt($encrypted);

echo '要解密的字符串:', $encrypted, '<br>解密后的字符串:', $decrypted;

經測試,結果和使用mcrypt加密結果一致。

【借鑒鏈接】:http://phpfiddle.org/lite/code/9epi-j5v2


免責聲明!

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



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