我正在尝试加密字符串,将其保存在文件中,然后从文件中读取字符串并解密。但是,当我运行代码时,我只是得到“解密的数据长度无效”错误:/通过调试我管理,发现由于某种原因字节数组(数组^字节)的长度为12,当我尝试解密字符串,当我加密字符串时,它的长度为8。
以下是加密字符串的代码:
String^ EncryptS(){
String^ DecryptedS;
MD5CryptoServiceProvider^ md5Crypt = gcnew MD5CryptoServiceProvider();
UTF8Encoding^ utf8Crypt = gcnew UTF8Encoding();
TripleDESCryptoServiceProvider^ crypt = gcnew TripleDESCryptoServiceProvider();
crypt->Key = md5Crypt->ComputeHash(utf8Crypt->GetBytes("123"));
crypt->Mode = CipherMode::ECB;
crypt->Padding = PaddingMode::PKCS7;
ICryptoTransform^ transCrypt = crypt->CreateEncryptor();
DecryptedS = utf8Crypt->GetString(transCrypt->TransformFinalBlock(utf8Crypt->GetBytes(form1::passwordTextBox->Text), 0, utf8Crypt->GetBytes(form1::passwordTextBox->Text)->Length));
return DecryptedS; }
这是解密字符串的代码
String^ decryptS(String^ encryptedS){
String^ decryptedS;
array<Byte>^ bytes;
MD5CryptoServiceProvider^ md5Crypt = gcnew MD5CryptoServiceProvider();
UTF8Encoding^ utf8Crypt = gcnew UTF8Encoding();
UTF8Encoding^ utf8ToByte = gcnew UTF8Encoding();
TripleDESCryptoServiceProvider^ crypt = gcnew TripleDESCryptoServiceProvider();
crypt->Key = md5Crypt->ComputeHash(utf8Crypt->GetBytes("123"));
crypt->Mode = CipherMode::ECB;
crypt->Padding = PaddingMode::PKCS7;
ICryptoTransform^ transCrypt = crypt->CreateDecryptor();
bytes = utf8ToByte->GetBytes(encryptedS);
return decryptedS = utf8Crypt->GetString(transCrypt->TransformFinalBlock(bytes, 0, bytes->Length)); }
我一直试图在几个小时内解决这个问题,但没有成功,将非常感谢帮助:)
抱歉我的英语不好。
答案 0 :(得分:4)
您正在尝试使用UTF-8将任意字节数组转换为字符串。这就像尝试加载一些随机文本文件一样,就像它是一个JPEG,并期望它是一个有效的图像。
当字节数组真的是使用该编码进行文本编码时,您应该只使用Encoding.GetString(byte[])
。
如果要表示“任意”二进制数据(通常是压缩或加密数据),则应使用base64或hex,具体取决于您的要求。 (Convert.ToBase64String
和Convert.FromBase64String
是您的朋友。)