Ver Mensaje Individual
  #1 (permalink)  
Antiguo 24/01/2011, 01:23
Avatar de aalleexx81
aalleexx81
 
Fecha de Ingreso: noviembre-2009
Mensajes: 153
Antigüedad: 15 años, 1 mes
Puntos: 0
Pregunta Problema con mcrypt

Hola a todos. Estoiy intentando usar las funciones de encriptación/desencriptación de php mcrypt. He editado el fichero php.ini incluyendo la dll, he comprobado que el fichero php.ini es el correcto con phpinfo() y que la dll está en la carpeta ext. Aun así el explorador me sigue lanzando los siguientes errores:


Notice: Use of undefined constant MCRYPT_MODE_ECB - assumed 'MCRYPT_MODE_ECB' in C:\Archivos de programa\Apache Software Foundation\Apache2.2\htdocs\Heracles\encripta.php on line 18

Notice: Use of undefined constant MCRYPT_RIJNDAEL_128 - assumed 'MCRYPT_RIJNDAEL_128' in C:\Archivos de programa\Apache Software Foundation\Apache2.2\htdocs\Heracles\encripta.php on line 19

Fatal error: Call to undefined function mcrypt_encrypt() in C:\Archivos de programa\Apache Software Foundation\Apache2.2\htdocs\Heracles\encripta.php on line 21


El código que utilizo 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;
    
$dec = @mcrypt_decrypt($enc$key$val$mode, @mcrypt_create_iv( @mcrypt_get_iv_size($enc$mode), MCRYPT_DEV_URANDOM ) );
    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 "epicsa";

echo 
"Cadena encriptada: ".mysql_aes_encrypt($cadena,$semilla)."<br>";
echo 
"Cadena desencriptada: ".mysql_aes_decrypt($cadena,$semilla)."<br>";

?>

No se dónde estoy metiendo la pata. Espero que alguno de vosotros me pueda orientar.

Un saludo y gracias a todos.