Hola a todos. Tengo el siguiente código en php, el cual encripta y desencripta la clave de cada usuario. El código es el siguiente:
Código PHP:
<?php
function mysql_aes_decrypt($val,$ky)
{
$key="\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";
for($a=0;$a<strlen($ky);$a++)
$key[$a%16]=chr(ord($key[$a%16]) ^ ord($ky[$a]));
$mode = MCRYPT_MODE_ECB;
$enc = MCRYPT_RIJNDAEL_128;
echo "MODE: $mode ENC: $enc KEY: $key <br>";
$dec = @mcrypt_decrypt($enc, $key, $val, $mode, @mcrypt_create_iv( @mcrypt_get_iv_size($enc, $mode), MCRYPT_RAND) );
return rtrim($dec,(( ord(substr($dec,strlen($dec)-1,1))>=0 and ord(substr($dec, strlen($dec)-1,1))<=16)? chr(ord( substr($dec,strlen($dec)-1,1))):null));
}
function mysql_aes_encrypt($val,$ky)
{
$key="\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";
for($a=0;$a<strlen($ky);$a++)
$key[$a%16]=chr(ord($key[$a%16]) ^ ord($ky[$a]));
$mode=MCRYPT_MODE_ECB;
$enc=MCRYPT_RIJNDAEL_128;
$val=str_pad($val, (16*(floor(strlen($val) / 16)+(strlen($val) % 16==0?2:1))), chr(16-(strlen($val) % 16)));
return mcrypt_encrypt($enc, $key, $val, $mode, mcrypt_create_iv( mcrypt_get_iv_size($enc, $mode), MCRYPT_DEV_URANDOM));
}
$cadena = "alex";
$semilla = "epicsa2011";
$enc = mysql_aes_encrypt($cadena,$semilla);
echo "Cadena encriptada: ".mysql_aes_encrypt($cadena,$semilla)."<br>";
echo "Cadena desencriptada: ".mysql_aes_decrypt($enc,$semilla)."<br>";
?>
El problema es que me lanza el siguiente warning 2 veces en la misma linea:
Warning: mcrypt_create_iv() [function.mcrypt-create-iv]: Cannot open source device in C:\PHP\...\encripta.php on line 23
Otra cosa que no entiendo es por qué las funciones @mcrypt_decrypt y @mcrypt_get_iv_size llevan una @ delante.
¿Alguien me puede decir que es lo que estoy haciendo mal?
Gracias a todos. Un saludo!!