PHP加密3DES报错 Call to undefined function: mcrypt_module_open() 的解决方法

我也是PHP新手,通过w3cschool了解了一下php基本原理之后就开写了。但仍是菜鸟。

先不管3DES加密的方法对不对,方法都是网上的,在运行的时候报了个错,把小弟整死了。找来找去终于自己摸出了方法。

<?php

/**
* 
* PHP版3DES加解密类
*
* 可与java的3DES(DESede)加密方式兼容
*
* @Author: Luo Hui (farmer.luo at gmail.com)
*
* @version: V0.1 2008.12.04
*
*/


class Crypt3Des
{    
    public $key    = "01234567890123456789012345678912";
    public $iv    = "23456789"; //like java: private static byte[] myIV = { 50, 51, 52, 53, 54, 55, 56, 57 };
    
    //加密
    public function encrypt($input)
    {
        $input = $this->padding( $input );
        $key = base64_decode($this->key);
        $td = mcrypt_module_open( MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
        //使用MCRYPT_3DES算法,cbc模式
        mcrypt_generic_init($td, $key, $this->iv);
        //初始处理
        $data = mcrypt_generic($td, $input);
        //加密
        mcrypt_generic_deinit($td);
        //结束
        mcrypt_module_close($td);
        $data = $this->removeBR(base64_encode($data));
        return $data;
    }
    
    //解密
    public function decrypt($encrypted)
    {
        $encrypted = base64_decode($encrypted);
        $key = base64_decode($this->key);
        $td = mcrypt_module_open( MCRYPT_3DES,'',MCRYPT_MODE_CBC,'');
        //使用MCRYPT_3DES算法,cbc模式
        mcrypt_generic_init($td, $key, $this->iv);
        //初始处理
        $decrypted = mdecrypt_generic($td, $encrypted);
        //解密
        mcrypt_generic_deinit($td);
        //结束
        mcrypt_module_close($td);
        $decrypted = $this->removePadding($decrypted);
        return $decrypted;
    }
    
    //填充密码,填充至8的倍数
    public function padding( $str )
    {
        $len = 8 - strlen( $str ) % 8;
        for ( $i = 0; $i < $len; $i++ )
        {
            $str .= chr( 0 );
        }
        return $str ;
    }
    
    //删除填充符
    public function removePadding( $str )
    {
        $len = strlen( $str );
        $newstr = "";
        $str = str_split($str);
        for ($i = 0; $i < $len; $i++ )
        {
            if ($str[$i] != chr( 0 ))
            {
                $newstr .= $str[$i];
            }
        }
        return $newstr;
    }
    
    //删除回车和换行
    public function removeBR( $str ) 
    {
        $len = strlen( $str );
        $newstr = "";
        $str = str_split($str);
        for ($i = 0; $i < $len; $i++ )
        {
            if ($str[$i] != '\n' and $str[$i] != '\r')
            {
                $newstr .= $str[$i];
            }
        }
    
        return $newstr;
    }

}

//test
$input = "1qaz2ws";
echo "plainText:" . $input."<br/>";
$crypt = new Crypt3Des();
echo "Encode:".$crypt->encrypt($input)."<br/>";
echo "Decode:".$crypt->decrypt($crypt->encrypt($input));
?>

代码可以不看,就看里面的一句:$td = mcrypt_module_open( MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');报错的就是他。

我搜寻了一大堆解决方法,正确的方法应该是(仅用于windows系统哦):

当运行php的服务器端缺少libmcrypt.dll时使用函数mcrypt_module_open进行解密会出现此错误。 
在服务器上做如下设置可解决。

到网上下载一个php的mcrypt模块安装包,只需要libmcrypt.dll文件即可(一般官网上下载的,php目录下已经有的)

1.将libmcrypt.dll复制到system32目录或php安装目录下的extensions目录下 
2.将libmcrypt.dll复制到apache安装目录的bin目录下 
3.到windows目录下找到php.ini文件,打开它
4.找到; Directory in which the loadable extensions (modules) reside. 
extension_dir = "./"  如:extension_dir = "D:\php5\ext"
这两行,要使extension_dir指向的目录下能找到libmcrypt.dll,或系统path下有libmcrypt.dll 
5.找到;Windows Extensions 项下面的;extension=php_mcrypt.dll这一行和;extension=php_iconv.dll(我的没有,省略了)这两行,去掉前面的分号

ps:刚开始看网上的解决方法,有的说修改php安装目录下的php.ini,但是修改后是没用的。一定要修改windows目录下的php.ini!

转载于:https://www.cnblogs.com/starksoft/p/5395915.html

如果你在执行上述代码时遇到了 `Call to undefined function mcrypt_get_block_size()` 这个错误,那么说明你的 PHP 环境中没有安装 `mcrypt` 扩展库。 在 PHP 7.2.0 版本中,`mcrypt` 扩展库已被弃用并在 PHP 7.2.0 中被移除。因此,如果你使用的是 PHP 7.2.0 或更高版本,那么无法使用 `mcrypt` 扩展库。 为了解决这个问题,你可以使用下面的代码来替换上述代码中的 `mcrypt` 函数: ```php <?php /** * AES加密 * @param string $data 要加密的数据 * @param string $key 密钥 * @param string $iv 初始化向量 * @return string */ function aes_encrypt($data, $key, $iv) { // PKCS7Padding 填充方式 $block_size = 16; $padding = $block_size - (strlen($data) % $block_size); $data .= str_repeat(chr($padding), $padding); // 加密 $method = 'aes-128-cbc'; $encrypted = openssl_encrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv); return base64_encode($encrypted); } /** * AES解密 * @param string $data 要解密的数据 * @param string $key 密钥 * @param string $iv 初始化向量 * @return string */ function aes_decrypt($data, $key, $iv) { // 解密 $method = 'aes-128-cbc'; $decrypted = openssl_decrypt(base64_decode($data), $method, $key, OPENSSL_RAW_DATA, $iv); // 去掉 PKCS7Padding 填充 $padding = ord($decrypted[strlen($decrypted)-1]); return substr($decrypted, 0, -$padding); } // 测试 $key = '1234567890123456'; // 密钥必须为16、24或32个字符 $iv = '1234567890123456'; // 初始化向量必须为16个字符 $data = 'Hello, world!'; $cipher_text = aes_encrypt($data, $key, $iv); $plain_text = aes_decrypt($cipher_text, $key, $iv); echo '明文: ' . $data . "\n"; echo '密文: ' . $cipher_text . "\n"; echo '解密后: ' . $plain_text . "\n"; ``` 需要注意的是,使用 `openssl_encrypt` 和 `openssl_decrypt` 函数进行加解密时,需要注意以下几点: 1. 对于 `aes-128-cbc` 加密算法,密钥必须为 16 个字符,初始化向量必须为 16 个字符,可以根据需要修改。 2. 在加密时需要进行 PKCS7Padding 填充,解密后需要去除填充。 3. 如果需要加密的数据不是 16 的整数倍,需要进行填充。填充的字节为缺少的字节数,填充的内容为缺少的字节数。例如,如果需要加密的数据为 `Hello, world!`,则缺少 5 个字节,需要填充 5 个字节,填充的内容为 `\x05\x05\x05\x05\x05`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值