我的代码有问题。函数解密器中存在问题。
“FlushFinalBlock抛出”填充无效,无法移除“
在函数解密器中,我得到长度为6048的myData,当行cryptoStream.Write(myData,0,myData.Length)完成时,在memoryStream中得到长度为6032,然后行cryptoStream.FlushFinalBlock();抛出一个错误“填充无效,不能删除”。
如您所见,我使用的是Padding = PaddingMode.PKCS7;
static RijndaelManaged rmCrypto;
static object lockCryptoStream = new object();
public static void SetrmCrypto()
{
rmCrypto = new RijndaelManaged();
rmCrypto.Padding = PaddingMode.PKCS7;
rmCrypto.KeySize = 128;
rmCrypto.Key = new ASCIIEncoding().GetBytes("xxxxxxxxxxxxxxxx");
rmCrypto.IV = new ASCIIEncoding().GetBytes("yyyyyyyyyyyyyyyy");
}
public static byte[] Encryptor(byte[] myData)
{
lock (lockCryptoStream)
{
using (var memoryStream = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(memoryStream, rmCrypto.CreateEncryptor(rmCrypto.Key, rmCrypto.IV), CryptoStreamMode.Write))
{
cryptoStream.Write(myData, 0, myData.Length);
cryptoStream.FlushFinalBlock();
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}
public static byte[] Decryptor(byte[] myData)
{
lock (lockCryptoStream)
{
using (var memoryStream = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(memoryStream, rmCrypto.CreateDecryptor(rmCrypto.Key, rmCrypto.IV), CryptoStreamMode.Write))
{
cryptoStream.Write(myData, 0, myData.Length);
cryptoStream.FlushFinalBlock();
cryptoStream.Close();
return memoryStream.ToArray();
}
}
}
}服务器上使用加密器,数据通过UDP发送。客户端使用解密器而不是解密数据。代码对大多数数据包都有效,让我们说它工作了几个小时,但之后,当我在法拉盛上得到那个错误时。
发布于 2015-10-21 07:49:15
上面的代码很好用。在我的例子中,问题发生在服务器上,服务器是在c++中输入的,而我在加密方面有问题(接收和发送时的线程问题)。
https://stackoverflow.com/questions/33165314
复制相似问题