Ich verweise auf diesen Artikel http://www.codeproject.com/KB/security/DotNetCrypto.aspx und ich versuche, eine verschlüsselte Zeichenfolge anstelle von Klartext zu schreiben. Im Folgenden finden Sie den Code, den ich verwende:
TextWriter tw = new StreamWriter("c:\\temp\\test.txt");
string plainString = "String to be encrypted";
PasswordDeriveBytes pdb = new PasswordDeriveBytes("Test",new byte[] {0x49, 0x76, 0x61, 0x6e, 0x20, 0x4d,0x65, 0x64, 0x76, 0x65, 0x64, 0x65, 0x76});
Rijndael alg = Rijndael.Create();
alg.Key = pdb.GetBytes(32);
alg.IV = pdb.GetBytes(16);
tw.WriteLine(alg.IV.ToString());
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms,alg.CreateEncryptor(), CryptoStreamMode.Write);
byte[] clearBytes = System.Text.Encoding.Unicode.GetBytes(plainString);
cs.Write(clearBytes, 0, clearBytes.Length);
cs.Close();
tw.WriteLine(ms.ToString());
ms.Close();
tw.Flush();
Wenn ich die Datei jedoch öffne, erhalte ich System.IO.MemoryStream
anstelle einiger verschlüsselter Zeichen. Was habe ich verpasst?