Ver Mensaje Individual
  #1 (permalink)  
Antiguo 27/01/2011, 01:35
Avatar de aalleexx81
aalleexx81
 
Fecha de Ingreso: noviembre-2009
Mensajes: 153
Antigüedad: 15 años
Puntos: 0
Pregunta Encriptación

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&#37;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))>=and ord(substr($decstrlen($dec)-1,1))<=16)? chr(ordsubstr($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$modemcrypt_create_ivmcrypt_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!!

Última edición por aalleexx81; 27/01/2011 a las 02:12