|
1 | | -using System; |
2 | | -using System.Collections.Generic; |
3 | | -using System.Linq; |
4 | | -using System.Text; |
5 | | -using System.Threading.Tasks; |
| 1 | +using System; |
6 | 2 | using System.IO; |
7 | 3 | using System.Security.Cryptography; |
8 | 4 |
|
9 | | -namespace Encryption_App |
| 5 | +namespace Aes |
10 | 6 | { |
11 | | - class Encryptor |
| 7 | + class AesEncryption |
12 | 8 | { |
13 | | - private static readonly string cryptFileEnding; |
| 9 | + public static void Main() |
| 10 | + { |
| 11 | + try |
| 12 | + { |
| 13 | + // Create a new instance of the AesManaged |
| 14 | + // class. This generates a new key and initialization |
| 15 | + // vector (IV). |
| 16 | + using (AesManaged myAes = new AesManaged()) |
| 17 | + { |
| 18 | + |
| 19 | + AES_Encrypt("file.txt", "file.crypt", new byte[10]); |
| 20 | + AES_Decrypt("file.crypt", "file.dcryptd", new byte[10]); |
| 21 | + } |
14 | 22 |
|
15 | | - public byte[] SymEncrypt(byte[] data, byte[] pwd) |
| 23 | + } |
| 24 | + catch (Exception e) |
| 25 | + { |
| 26 | + Console.WriteLine("Error: {0}", e.Message); |
| 27 | + } |
| 28 | + Console.Read(); |
| 29 | + } |
| 30 | + private static void AES_Encrypt(string iF, string oF, byte[] passwordBytes) |
16 | 31 | { |
| 32 | + |
17 | 33 | byte[] saltBytes = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 }; |
18 | 34 |
|
19 | | - using (var ms = new MemoryStream()) |
| 35 | + using (var outFile = File.Create(oF)) |
20 | 36 | { |
21 | | - using (var AES = new AesManaged()) |
| 37 | + |
| 38 | + using (var AES = new RijndaelManaged()) |
22 | 39 | { |
| 40 | + |
23 | 41 | AES.KeySize = 256; |
24 | 42 | AES.BlockSize = 128; |
25 | | - AES.Padding = PaddingMode.PKCS7; |
26 | | - AES.Mode = CipherMode.CBC; |
27 | | - |
28 | | - var key = new Rfc2898DeriveBytes(pwd, saltBytes, 1000); |
| 43 | + var key = new Rfc2898DeriveBytes(passwordBytes, saltBytes, 100000); |
29 | 44 | AES.Key = key.GetBytes(AES.KeySize / 8); |
30 | 45 | AES.IV = key.GetBytes(AES.BlockSize / 8); |
31 | | - Console.WriteLine(Encoding.UTF8.GetString(AES.Key)); |
32 | | - Console.WriteLine(Encoding.UTF8.GetString(AES.IV)); |
| 46 | + AES.Padding = PaddingMode.PKCS7; |
| 47 | + AES.Mode = CipherMode.CBC; |
33 | 48 |
|
34 | | - using (var cs = new CryptoStream(ms, AES.CreateEncryptor(), CryptoStreamMode.Write)) |
| 49 | + using (var cs = new CryptoStream(outFile, AES.CreateEncryptor(), CryptoStreamMode.Write)) |
35 | 50 | { |
36 | | - using (var bw = new BinaryWriter(cs)) |
| 51 | + |
| 52 | + using (var inFile = File.OpenRead(iF)) |
37 | 53 | { |
38 | | - try |
39 | | - { |
40 | | - bw.Write(data, 0, data.Length); |
41 | | - } |
42 | | - catch(Exception ex) |
| 54 | + |
| 55 | + using (var br = new BinaryReader(inFile)) |
43 | 56 | { |
44 | | - return null; |
| 57 | + |
| 58 | + sbyte data; |
| 59 | + while ((data = (sbyte)inFile.ReadByte()) != -1) |
| 60 | + cs.WriteByte((byte)data); |
| 61 | + |
45 | 62 | } |
46 | 63 | } |
47 | 64 | } |
48 | | - return ms.ToArray(); |
49 | 65 | } |
50 | 66 | } |
51 | 67 | } |
52 | 68 |
|
53 | | - public byte[] SymDecrypt(byte[] data, byte[] pwd) |
| 69 | + private static void AES_Decrypt(string iF, string oF, byte[] passwordBytes) |
54 | 70 | { |
| 71 | + |
55 | 72 | byte[] saltBytes = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 }; |
56 | 73 |
|
57 | | - using (var ms = new MemoryStream()) |
| 74 | + using (var inFile = File.OpenRead(iF)) |
58 | 75 | { |
59 | | - using (AesManaged AES = new AesManaged()) |
| 76 | + |
| 77 | + using (var AES = new RijndaelManaged()) |
60 | 78 | { |
| 79 | + |
61 | 80 | AES.KeySize = 256; |
62 | 81 | AES.BlockSize = 128; |
63 | | - AES.Padding = PaddingMode.PKCS7; |
64 | | - AES.Mode = CipherMode.CBC; |
65 | | - |
66 | | - var key = new Rfc2898DeriveBytes(pwd, saltBytes, 1000); |
| 82 | + var key = new Rfc2898DeriveBytes(passwordBytes, saltBytes, 100000); |
67 | 83 | AES.Key = key.GetBytes(AES.KeySize / 8); |
68 | 84 | AES.IV = key.GetBytes(AES.BlockSize / 8); |
| 85 | + AES.Padding = PaddingMode.PKCS7; |
| 86 | + AES.Mode = CipherMode.CBC; |
69 | 87 |
|
70 | | - using (var cs = new CryptoStream(ms, AES.CreateDecryptor(), CryptoStreamMode.Write)) |
| 88 | + using (var cs = new CryptoStream(inFile, AES.CreateDecryptor(), CryptoStreamMode.Read)) |
71 | 89 | { |
72 | | - try |
| 90 | + |
| 91 | + using (var outFile = File.Create(oF)) |
73 | 92 | { |
74 | | - cs.Write(data, 0, data.Length); |
75 | | - } |
76 | | - catch(Exception ex) |
77 | | - { |
78 | | - return null; |
| 93 | + |
| 94 | + sbyte data; |
| 95 | + while ((data = (sbyte)cs.ReadByte()) != -1) |
| 96 | + outFile.WriteByte((byte)data); |
| 97 | + |
79 | 98 | } |
80 | 99 | } |
81 | | - return ms.ToArray(); |
82 | 100 | } |
83 | 101 | } |
84 | 102 | } |
|
0 commit comments