我需要解密存储在mysql数据库中的数据。
它在我的测试中工作,但现在它是实时的,用户正在提交数据,输出数据不能解密成任何可读的。
function encrypt($text,$key){
$key = md5("Salt1". $key . "Salt2");
return trim(
base64_encode(
mcrypt_encrypt(
MCRYPT_RIJNDAEL_256,
$key,
$text,
MCRYPT_MODE_ECB,
mcrypt_create_iv(
mcrypt_get_iv_size(
MCRYPT_RIJNDAEL_256,
MCRYPT_MODE_ECB
),
MCRYPT_RAND
)
)
)
);
}
数据在提交时被加密,密钥数据来自同一行的几列。
但使用:
function decrypt($text,$key){
$key = md5("Salt1". $key . "Salt2");
return trim(
mcrypt_decrypt(
MCRYPT_RIJNDAEL_256,
$key,
base64_decode($text),
MCRYPT_MODE_ECB,
mcrypt_create_iv(
mcrypt_get_iv_size(
MCRYPT_RIJNDAEL_256,
MCRYPT_MODE_ECB
),
MCRYPT_RAND
)
)
);
}
我只会得到更多加密的垃圾。
我需要另一种解决方案,而不是告诉用户返回并更新他们的信息。
[$salt1
和$salt2
]这些是来自另一个源的静态文本块。我能得到我的一些数据可以解密,但我无法获得我使用的其他数据日期("r")作为键的一部分。
抱歉,如果我说的很明显,但date("r")
每秒钟打印一个不同的值:
Wed, 07 Dec 2011 17:35:44 +0100
如果您将其用作加密密钥的一部分,则需要恢复生成密钥的确切时间,包括精确的秒和时区。问题是,你存起来了吗?