AES-128-ECB php兼容高低版本

class Aes {
    /**
     * 加密
     * @param $plain
     * @param $key
     * @return false|string
     */
    public static function encrypt($plain, $key)
    {
        if (trim($key) == '') {
            return false;
        }
        $key = self::_sha1prng($key);
        if(version_compare(PHP_VERSION,'7.1','>=')){
            $iv = '';
            $encrypted = openssl_encrypt($plain, 'AES-128-ECB', $key, OPENSSL_RAW_DATA, $iv);
        }else{
            $plain       = strval($plain);
            $block_size  = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
            $padded_data = self::_pkcs5_pad($plain, $block_size);
            $iv_size     = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
            $iv          = mcrypt_create_iv($iv_size, MCRYPT_RAND);
            $encrypted   = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $padded_data, MCRYPT_MODE_ECB, $iv);
        }
        return base64_encode($encrypted);
    }

    /**
     * aes解密
     * @param $cipher   密文
     * @param $key
     * @return false|string
     */
    public static function decrypt($cipher, $key)
    {
        if ( ! is_string($cipher) || trim($key) == '') {
            return false;
        }
        $key = self::_sha1prng($key);
        $decoded = base64_decode($cipher);
        if ($decoded){
            if(version_compare(PHP_VERSION,'7.1','>=')){
                $iv = '';
                return  openssl_decrypt($decoded, 'AES-128-ECB', $key, OPENSSL_RAW_DATA, $iv);
            }else{
                $block_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
                $iv         = mcrypt_create_iv($block_size, MCRYPT_RAND);
                $decrypted  = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $decoded, MCRYPT_MODE_ECB, $iv);
                return self::_pkcs5_unpad($decrypted);
            }
        }
        return false;
    }

    /**
     * SHA1PRNG算法
     * @param $key
     * @return string
     */
    private static function _sha1prng($key)
    {
        return substr(openssl_digest(openssl_digest($key, 'sha1', true), 'sha1', true), 0, 16);
    }

    private static function _pkcs5_pad($text, $block_size)
    {
        $pad = $block_size - (strlen($text) % $block_size);
        return $text . str_repeat(chr($pad), $pad);
    }

    private static function _pkcs5_unpad($text)
    {
        $end  = substr($text, -1);
        $last = ord($end);
        $len  = strlen($text) - $last;
        if (substr($text, $len) == str_repeat($end, $last)) {
            return substr($text, 0, $len);
        }
        return false;
    }
}

//使用方法:
$keyStr = 'sdez';
$aes = new Aes();
$str = '{"openCode":"a9ae-8394-49bb","phone":"9988","name":"test","type":"2"}';
$chgstr = $aes->encrypt($str,$keyStr);
echo $chgstr;
echo PHP_EOL;
$rstr = $aes->decrypt($chgstr,$keyStr);
echo $rstr;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AES-128-ECB是一种加密算法,其中AES代表高级加密标准(Advanced Encryption Standard),128代表密钥长度为128位,ECB代表电子密码本(Electronic Codebook)模式。 在PHP中,可以使用内置的openssl扩展来实现AES-128-ECB加密。首先,需要创建一个密钥,一个具有128位长度的密钥。然后,可以使用openssl_encrypt函数来加密明文数据。 下面是一个使用AES-128-ECB加密和解密数据的PHP示例代码: ```php <?php function encrypt($data, $key) { $encrypted_data = openssl_encrypt($data, 'AES-128-ECB', $key, OPENSSL_RAW_DATA); $base64_encrypted_data = base64_encode($encrypted_data); return $base64_encrypted_data; } function decrypt($encrypted_data, $key) { $encrypted_data = base64_decode($encrypted_data); $decrypted_data = openssl_decrypt($encrypted_data, 'AES-128-ECB', $key, OPENSSL_RAW_DATA); return $decrypted_data; } // 使用一个密钥进行加密和解密 $key = "0123456789012345"; $data = "这是要加密的数据"; $encrypted_data = encrypt($data, $key); $decrypted_data = decrypt($encrypted_data, $key); echo "加密后的数据:" . $encrypted_data . "\n"; echo "解密后的数据:" . $decrypted_data . "\n"; ?> ``` 在上述代码中,我们定义了encrypt和decrypt两个函数来对数据进行加密和解密操作。首先,使用openssl_encrypt函数来加密数据,然后使用base64_encode函数将加密后的数据进行Base64编码。在解密时,首先使用base64_decode函数将加密数据进行Base64解码,然后使用openssl_decrypt函数对解码后的数据进行解密操作。 注意:AES-128-ECB模式不具备数据完整性保护,因此在实际应用中,建议使用更安全的加密模式,如AES-128-CBC模式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值