Io uso questa classe:
codice:
<?php
Class Crypt128
{
private function get_rnd_iv ($iv_len)
{
$iv = '';
while ($iv_len-- > 0)
{
$iv .= chr (mt_rand () & 0xff);
}
return $iv;
}
public function encrypt ($plain_text, $password, $iv_len = 16)
{
$plain_text .= "\x13";
$n = strlen ($plain_text);
if ($n % 16)
$plain_text .= str_repeat ("\0", 16 - ($n % 16));
$i = 0;
$enc_text = get_rnd_iv ($iv_len);
$iv = substr ($password ^ $enc_text, 0, 512);
while ($i < $n)
{
$block = substr ($plain_text, $i, 16) ^ pack ('H*', md5 ($iv));
$enc_text .= $block;
$iv = substr ($block . $iv, 0, 512) ^ $password;
$i += 16;
}
return base64_encode ($enc_text);
}
public function decrypt ($enc_text, $password, $iv_len = 16)
{
$enc_text = base64_decode ($enc_text);
$n = strlen ($enc_text);
$i = $iv_len;
$plain_text = '';
$iv = substr ($password ^ substr ($enc_text, 0, $iv_len), 0, 512);
while ($i < $n)
{
$block = substr ($enc_text, $i, 16);
$plain_text .= $block ^ pack ('H*', md5 ($iv));
$iv = substr ($block . $iv, 0, 512) ^ $password;
$i += 16;
}
return preg_replace ('/\\x13\\x00*$/', '', $plain_text);
}
}
?>
Crypta e decrypta a 128 bit con password, di conseguenza riesci a decryptare solo se conosci la pass con cui è stato cryptato.
Ho trovato il codice su inet e lo ho trasformato in classe