using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Security.Cryptography; namespace AES
{
public partial class Form1 : Form
{ public Form1()
{
InitializeComponent();
} private void btnEncrypt_Click(object sender, EventArgs e)
{
string toEncrypt = txtString.Text.Trim().ToString();
string key = txtKey.Text.Trim().ToString();
string iv = txtIv.Text.Trim().ToString();
lblResult.Text = Encrypt(toEncrypt, key, iv);
} private void btnDecrypt_Click(object sender, EventArgs e)
{
string toEncrypt = txtString.Text.Trim().ToString();
string key = txtKey.Text.Trim().ToString();
string iv = txtIv.Text.Trim().ToString();
lblResult.Text = Decrypt(toEncrypt, key, iv);
} public static string Encrypt(string toEncrypt, string key, string iv)
{ byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
byte[] ivArray = UTF8Encoding.UTF8.GetBytes(iv);
byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(toEncrypt); RijndaelManaged rDel = new RijndaelManaged();
rDel.Key = keyArray;
rDel.IV = ivArray;
rDel.Mode = CipherMode.CBC;
rDel.Padding = PaddingMode.Zeros; ICryptoTransform cTransform = rDel.CreateEncryptor();
byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, , toEncryptArray.Length); return Convert.ToBase64String(resultArray, , resultArray.Length);
} public static string Decrypt(string toDecrypt, string key, string iv)
{
byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
byte[] ivArray = UTF8Encoding.UTF8.GetBytes(iv);
byte[] toEncryptArray = Convert.FromBase64String(toDecrypt); RijndaelManaged rDel = new RijndaelManaged();
rDel.Key = keyArray;
rDel.IV = ivArray;
rDel.Mode = CipherMode.CBC;
rDel.Padding = PaddingMode.Zeros; ICryptoTransform cTransform = rDel.CreateDecryptor();
byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, , toEncryptArray.Length); return UTF8Encoding.UTF8.GetString(resultArray);
}
}
}