Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/233.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
php加密在5.6或更高版本中不起作用?_Php_Encryption - Fatal编程技术网

php加密在5.6或更高版本中不起作用?

php加密在5.6或更高版本中不起作用?,php,encryption,Php,Encryption,我使用这段代码来加密密码,但它不适用于PHP5.6或更高版本。请建议我在不改变算法的情况下使用新代码 请在不改变算法的情况下给我新代码 <?php class Encryption { var $skey = "844958uyjd875e89t5f4h6j4h5g"; // you can change it public function safe_b64encode($string) { $data = base64_encode($string);

我使用这段代码来加密密码,但它不适用于PHP5.6或更高版本。请建议我在不改变算法的情况下使用新代码

请在不改变算法的情况下给我新代码

<?php
class Encryption {
    var $skey = "844958uyjd875e89t5f4h6j4h5g"; // you can change it

    public function safe_b64encode($string) {
        $data = base64_encode($string);
        $data = str_replace(array('+','/','='),array('-','_',''),$data);
        return $data;
    }

    public function safe_b64decode($string) {
        $data = str_replace(array('-','_'),array('+','/'),$string);
        $mod4 = strlen($data) % 4;
        if ($mod4) {
            $data .= substr('====', $mod4);
        }
        return base64_decode($data);
    }

    public function encode($value){ 
        if(!$value){return false;}
        $text = $value;
        $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
        $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
        $crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $this->skey, $text, MCRYPT_MODE_ECB, $iv);
        return trim($this->safe_b64encode($crypttext)); 
    }

    public function decode($value){
        if(!$value){return false;}
        $crypttext = $this->safe_b64decode($value); 
        $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
        $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
        $decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $this->skey, $crypttext, MCRYPT_MODE_ECB, $iv);
        return trim($decrypttext);
    }
}
?>

只需使用
密码\u散列
密码\u验证
。这是保护密码最安全的方法。 例如:

$password_hash = password_hash("yourpassword", PASSWORD_DEFAULT);

if (password_verify('yourpassword', $password_hash)) {
    echo 'Password is valid!';
} else {
    echo 'Invalid password.';
}

为什么要用这种方式加密密码?!?“不起作用”是什么意思?错误?错误的结果?不管怎样。您不应该存储加密的密码。这是一个重大的安全风险。您应该只保存密码哈希!首先检查是否安装了mcrypt?。如果未安装,请从第三方安装。@MagnusEriksson我怀疑这是用于存储的。看起来更像是传输密码的解决方案,因为如果使用64位编码。这就是为什么我要求安装php-mcrypt的原因?