这是解密$data内容的PHP代码:
$data='DwRktl1y8st4k11pSxy2tE9kJMiNlIgV6Gu9ekY8ia2QtoGbdiaiemHeQJ+2MGTZmRKM0IGsiXQyqvXLx/t47FcXmwzZPayS3i6mmYD+qFibbcmA5lGI1uIjT7FSgLM9Xi9QBnTMjIwIEmv6tQaKGGTbhwvUuaP7hek57Xnlk+9CCarkkDlGLed5y+6GedXED0KgMcW1rqXLH7EQub+KzQ==';
$crypttext = base64_decode($data);
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, 'AbcNtByIGI1BpgcsAG8GZl8pdwwxyz', $crypttext, MCRYPT_MODE_ECB, $iv);
我试过这是.net,但它不起作用:
string data = "DwRktl1y8st4k11pSxy2tE9kJMiNlIgV6Gu9ekY8ia2QtoGbdiaiemHeQJ+2MGTZmRKM0IGsiXQyqvXLx/t47FcXmwzZPayS3i6mmYD+qFibbcmA5lGI1uIjT7FSgLM9Xi9QBnTMjIwIEmv6tQaKGGTbhwvUuaP7hek57Xnlk+9CCarkkDlGLed5y+6GedXED0KgMcW1rqXLH7EQub+KzQ==";
byte[] arrb = Convert.FromBase64String(data);
string decodedString = Encoding.UTF8.GetString(arrb);
const string key = "AbcNtByIGI1BpgcsAG8GZl8pdwwxyz";
RijndaelManaged aes = new RijndaelManaged();
aes.KeySize = 256;
aes.BlockSize = 256;
aes.Padding = PaddingMode.None;
aes.Mode = CipherMode.ECB;
aes.GenerateIV();
ICryptoTransform decryptor = aes.CreateDecryptor(Encoding.UTF8.GetBytes(key), aes.IV);
MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(decodedString.Trim()));
CryptoStream cs = new CryptoStream(ms, decryptor, CryptoStreamMode.Read);
StreamReader sr = new StreamReader(cs);
user_data = sr.ReadToEnd();
我收到异常"要解密的数据长度无效"。谁能建议我可能出错的地方?
不是一个完整的解决方案,但你应该摆脱decodedString。 数据保存 base64 编码的加密二进制数据。 ARRB 保存 160 字节的加密二进制数据。 arrb 是您需要传递给解密的内容,不要进行从二进制到字符串然后字符串到二进制的转换,这会丢失信息。