getkirby-v2/toolkit

mcrypt_get_iv_size is deprecated since php 7.1

covovker opened this issue · 8 comments

Subj causes "function is deprecated" message to appear on the screen when encryption is used in php 7.1+.

The entire ext/mcrypt has been deprecated as of 7.1. For PHP 7.1 you need an entirely different encryption class than currently in the toolkit.

Converting to OpenSSL for 7.1 would be an option, though as of 7.2 you would probably want to use ext/sodium.

We are aware of this issue, but we can't currently do anything about it as Kirby 2 still supports PHP 5.4+. libsodium would definitely be the way to go, but we can't do this in Kirby 2.

Kirby 3 will drop support for PHP 5, so we will consider this there. Either we will drop support for PHP 7.0 and 7.1 as well (a bit risky as few hosting providers will support 7.2 that soon) or we will implement libsodium with a fallback to OpenSSL in case libsodium is not available.

You could apply something like this to crypt.php to hide the deprecation messages and keep all other error reporting intact:

diff --git a/lib/crypt.php b/lib/crypt.php
index 9399f7f..cf8cf9a 100644
--- a/lib/crypt.php
+++ b/lib/crypt.php
@@ -46,10 +46,15 @@ class Crypt {
     // check for a valid encryption mode
     if(!in_array($mode, static::$encryption)) throw new Exception('Invalid encryption mode: ' . $mode);

+    // mcrypt is deprecated in 7.1, hide deprecation notices
+    $error_reporting = error_reporting(error_reporting() & ~E_DEPRECATED);
+
     $size   = mcrypt_get_iv_size($mode, MCRYPT_MODE_ECB);
     $iv     = mcrypt_create_iv($size, MCRYPT_RAND);
     $result = mcrypt_encrypt($mode, static::$salt . $key, $text, MCRYPT_MODE_ECB, $iv);

+    error_reporting($error_reporting);
+
     return trim($result);

   }
@@ -75,10 +80,15 @@ class Crypt {
     // check for a valid encryption mode
     if(!in_array($mode, static::$encryption)) throw new Exception('Invalid encryption mode: ' . $mode);

+    // mcrypt is deprecated in 7.1, hide deprecation notices
+    $error_reporting = error_reporting(error_reporting() & ~E_DEPRECATED);
+
     $size   = mcrypt_get_iv_size($mode, MCRYPT_MODE_ECB);
     $iv     = mcrypt_create_iv($size, MCRYPT_RAND);
     $result = mcrypt_decrypt($mode, static::$salt . $key, $text, MCRYPT_MODE_ECB, $iv);

+    error_reporting($error_reporting);
+
     return trim($result);

   }

Ok, thanks

which function can i use instead of this?

That depends on your use-case. What do you want to encrypt and why?

i use mcrypt to encrypt my password in php7.0,now i want to upgrade php7.2。so i need a function to be compatible

You should never encrypt passwords. Instead hash them using PHP’s password_hash().