我有一个php mcrypt_decrypt
函数的小问题。首先,我使用一个16字节的字符串,并使用mcrypt_encrypt
加密;然后,我使用base64_encode
,并把输出到mcrypt_decrypt
,以获得初始字符串。
但是输出不是预期的。我检查了我的base64
解码字符串输入解码是mcrypt_decrypt
产生的确切输出。下面是我的代码:
//encrypt
$str="KKQT9W4st7vmdkps";
$key="43625A8C1E4330BDF84DDEE3DD105037";
$block = mcrypt_get_block_size('rijndael_128', 'ecb');
$passcrypt=mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $str, MCRYPT_MODE_ECB);
echo $passcrypt;
输出PTfZ6Ephh8LTxXL4In33Og==
。解密脚本如下:
//decrypt
$str='PTfZ6Ephh8LTxXL4In33Og==';
$key='43625A8C1E4330BDF84DDEE3DD105037';
$str = base64_decode($str);
$str = rtrim(mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key,
$str, MCRYPT_MODE_ECB,''),"'0");
$block = mcrypt_get_block_size('rijndael_128', 'ecb');
echo $str;
输出不是KKQT9W4st7vmdkps
,而是-nγ kk7Ζn’T
。什么好主意吗?我使用XAMPP和Apache服务器
感谢大家的反馈,这是我犯的一个愚蠢的错误…实际上'PTfZ6Ephh8LTxXL4In33Og=='在解密功能中是错误的,因为"I"最终是"l"…所以解密是不正确的…但这也不是我的错,因为我从QR码扫描仪中得到这个字符串,"I"answers"l"都显示相同…
对于加密,您需要:
1)创建一个加密资源$str = "KKQT9W4st7vmdkps";
$key = "43625A8C1E4330BDF84DDEE3DD105037";
$r = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '',MCRYPT_MODE_ECB, '');
2)根据$r
的大小随机生成加密向量
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($r),MCRYPT_RAND);
3)使用资源、键和字符串向量初始化模块
mcrypt_generic_init($r,$key,$iv);
4)使用资源$r
加密数据/字符串
$encrypted = mcrypt_generic($r,$str);
5)用base64_encode
编码
$encoded = base64_encode($encrypted);
if(!mcrypt_generic_deinit($r) || !mcrypt_module_close($r))
$encoded = false;
echo 'Encrypted: '.$encoded;
对于解密,它就像加密的反向过程
//Using the same enrypted string
$decoded = (string) base64_decode(trim($encoded));
$td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '',MCRYPT_MODE_ECB, '');
$ivs = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
mcrypt_generic_init($td,$key, $ivs);
$decoded = (string) trim(mdecrypt_generic($td, $decoded));
if(!mcrypt_generic_deinit($td) || !mcrypt_module_close($td))
$decoded = false;
与
echo 'Decrypted: '. $decoded;
希望这对你有帮助。