webentwicklung-frage-antwort-db.com.de

Die Funktion mcrypt_create_iv () ist innerhalb des CodeIgniter-Frameworks veraltet

<?php 
class Encryption {
    var $skey     = "1234561234561234"; // 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);
    }

}

Es ist meine encryption.php-Datei. Ich habe versucht, diesen Fehler zu lösen und viel Zeit zu recherchieren, aber ich konnte keine richtige Antwort finden. Ich bin neu in PHP.

Error :

Ein PHP Fehler wurde gefunden

Schweregrad: 8192

Nachricht: Die Funktion mcrypt_create_iv () ist veraltet

Dateiname: Bibliotheken/Verschlüsselung.php

Zeilennummer: 27

2
prakash pokhrel

Das Handbuch http://php.net/manual/de/function.mcrypt-create-iv.php heißt:

Warnung

Diese Funktion wurde in PHP 7.1.0 DEPRECATED und in PHP 7.2.0 ENTFERNT. 

Alternativen zu dieser Funktion sind:

Wenn Sie random_bytes() nicht verwenden möchten, gibt es eine alternative Lösung, die hier angezeigt wird:

8