mcrypt 如何加/解密 ?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mcrypt 如何加/解密 ?相关的知识,希望对你有一定的参考价值。

参考技术A /* 开启加密算法/ */$td = mcrypt_module_open('twofish', '', 'ecb', '');/* 建立 IV,并检测 key 的长度 */$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);$ks = mcrypt_enc_get_key_size($td);/* 生成 key */$key = substr(md5('very secret key'), 0, $ks);/* 初始化加密程序 */mcrypt_generic_init($td, $key, $iv);/* 加密, $encrypted 保存的是已经加密后的数据 */print $encrypted = mcrypt_generic($td, 'This is very important data');/* 检测加密句柄 */mcrypt_generic_deinit($td);/* 初始化加密模块,用以解密 */mcrypt_generic_init($td, $key, $iv);/* 解密 */$decrypted = mdecrypt_generic($td, $encrypted);/* 检测解密句柄,并关闭模块 */mcrypt_generic_deinit($td);mcrypt_module_close($td);/* 显示原始字符串 */本回答被提问者采纳

PHP微信开放平台---消息加解密-php7.1 使用openssl代替Mcrypt

1、问题

微信开发小程序消息加解密,官方给出的dome中使用正常,最近升级了7.1发现接收消息不能解密了,最后查了日志又查了各种资料发现 Mcrypt 函数php7.1已经被废弃; 

2、解决方式

Prpcrypt类中使用openssl代替Mcrypt

官方代码:

/**
     * 对密文进行解密
     * @param string $encrypted 需要解密的密文
     * @return string 解密得到的明文
     */
    public function decrypt($encrypted, $appid)
    {

        try {
            //使用BASE64对需要解密的字符串进行解码
            $ciphertext_dec = base64_decode($encrypted);
            $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, ‘‘, MCRYPT_MODE_CBC, ‘‘);
            $iv = substr($this->key, 0, 16);
            mcrypt_generic_init($module, $this->key, $iv);

            //解密
            $decrypted = mdecrypt_generic($module, $ciphertext_dec);
            mcrypt_generic_deinit($module);
            mcrypt_module_close($module);
        } catch (Exception $e) {
            return array(ErrorCode::$DecryptAESError, null);
        }


        try {
            //去除补位字符
            $pkc_encoder = new PKCS7Encoder;
            $result = $pkc_encoder->decode($decrypted);
            //去除16位随机字符串,网络字节序和AppId
            if (strlen($result) < 16)
                return "";
            $content = substr($result, 16, strlen($result));
            $len_list = unpack("N", substr($content, 0, 4));
            $xml_len = $len_list[1];
            $xml_content = substr($content, 4, $xml_len);
            $from_appid = substr($content, $xml_len + 4);
        } catch (Exception $e) {
            //print $e;
            return array(ErrorCode::$IllegalBuffer, null);
        }
        if ($from_appid != $appid)
            return array(ErrorCode::$ValidateAppidError, null);
        return array(0, $xml_content);

    }

修改之后代码:

/**
     * 对密文进行解密
     * @param string $encrypted 需要解密的密文
     * @return string 解密得到的明文
     */
    public function decrypt($encrypted, $appid)
    {

        try {
            $iv = substr($this->key, 0, 16);
            $decrypted = openssl_decrypt(base64_decode($encrypted),‘AES-256-CBC‘,$this->key,OPENSSL_RAW_DATA,$iv);
           
        } catch (Exception $e) {
            return array(ErrorCode::$DecryptAESError, null);
        }
        try {
            //去除补位字符
            $pkc_encoder = new PKCS7Encoder;
            $result = $pkc_encoder->decode($decrypted);
            //去除16位随机字符串,网络字节序和AppId
            if (strlen($result) < 16)
                return "";
            $content = substr($result, 16, strlen($result));
            $len_list = unpack("N", substr($content, 0, 4));
            $xml_len = $len_list[1];
            $xml_content = substr($content, 4, $xml_len);
            $from_appid = substr($content, $xml_len + 4);
         
        } catch (Exception $e) {
            //print $e;
            return array(ErrorCode::$IllegalBuffer, null);
        }
        if ($from_appid != $appid)
            return array(ErrorCode::$ValidateAppidError, null);
        return array(0, $xml_content);

    }

 

以上是关于mcrypt 如何加/解密 ?的主要内容,如果未能解决你的问题,请参考以下文章

php升级到7.+之后openssl替代mcrypt实现解密

mcrypt_crypt 和解密结果不匹配

PHP如何实现AES加解密

使用php mcrypt加密解密

使用php mcrypt加密解密

如何使用mcrypt解密