在C#中实现对称加密,你可以使用.NET框架自带的System.Security.Cryptography命名空间中的类。以下是一个使用AES算法的简单示例:
-
首先,确保你已经安装了.NET Framework或.NET Core。
-
创建一个新的C#控制台应用程序项目。
-
在项目中添加以下命名空间引用:
using System; using System.Text; using System.Security.Cryptography;
- 在Main方法中,编写以下代码:
class Program
{
static void Main(string[] args)
{
string plaintext = "Hello, World!";
string key = "ThisIsASecretKey!";
string ciphertext = Encrypt(plaintext, key);
Console.WriteLine("Plaintext: " + plaintext);
Console.WriteLine("Ciphertext: " + ciphertext);
string decryptedText = Decrypt(ciphertext, key);
Console.WriteLine("Decrypted Text: " + decryptedText);
}
static byte[] Encrypt(string plaintext, string key)
{
using (Aes aesAlg = Aes.Create())
{
byte[] keyBytes = Encoding.UTF8.GetBytes(key);
byte[] initVectorBytes = Encoding.UTF8.GetBytes("ThisIsASecretInitVector!");
aesAlg.Key = keyBytes;
aesAlg.IV = initVectorBytes;
ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);
using (var msEncrypt = new System.IO.MemoryStream())
{
using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
{
using (var swEncrypt = new StreamWriter(csEncrypt))
{
swEncrypt.Write(plaintext);
}
}
return msEncrypt.ToArray();
}
}
}
static string Decrypt(byte[] cipherText, string key)
{
using (Aes aesAlg = Aes.Create())
{
byte[] keyBytes = Encoding.UTF8.GetBytes(key);
byte[] initVectorBytes = Encoding.UTF8.GetBytes("ThisIsASecretInitVector!");
aesAlg.Key = keyBytes;
aesAlg.IV = initVectorBytes;
ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);
using (var msDecrypt = new System.IO.MemoryStream(cipherText))
{
using (var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
{
using (var srDecrypt = new StreamReader(csDecrypt))
{
return srDecrypt.ReadToEnd();
}
}
}
}
}
}
在这个示例中,我们使用了AES加密算法,并创建了一个简单的控制台应用程序来加密和解密字符串。请注意,为了简化示例,我们使用了一个固定的密钥和初始化向量(IV)。在实际应用中,你应该使用更安全的方式来生成和存储密钥和IV。