C#实现AES加密字符串
时间: 2023-12-27 14:03:55 浏览: 33
C是一种流行的编程语言,它被广泛用于操作系统、嵌入式系统、网络应用程序、图形应用程序等领域。C语言提供了很强的控制结构、高效的内存管理和指针操作等特性,因此被称为“程序员的语言”。C语言也被称为低级语言,因为它处理硬件和系统有更直接的接口,而不是像高级语言一样隐藏了这些底层细节。C语言的标准由ISO组织和ANSI制定,其流行度不亚于Java、Python等编程语言。
相关问题
C# 实现 JAVA AES加密解密
C# 和 Java 都支持 AES 加密算法,因此可以在两种语言中进行加密和解密。下面是一个示例代码,演示了 C# 和 Java 中如何使用 AES 加密和解密数据。
首先是 Java 中的代码,用于加密数据:
```java
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
public class AesEncryption {
private static final String ALGORITHM = "AES/CBC/PKCS5Padding";
private static final String KEY = "0123456789abcdef"; // 16-byte key
private static final String IV = "0123456789abcdef"; // 16-byte initialization vector
public static String encrypt(String data) throws Exception {
Cipher cipher = Cipher.getInstance(ALGORITHM);
SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(), "AES");
IvParameterSpec ivSpec = new IvParameterSpec(IV.getBytes());
cipher.init(Cipher.ENCRYPT_MODE, keySpec, ivSpec);
byte[] encrypted = cipher.doFinal(data.getBytes());
return Base64.getEncoder().encodeToString(encrypted);
}
}
```
这个代码使用了 AES/CBC/PKCS5Padding 加密算法,采用了 16 字节的密钥和初始化向量。`encrypt()` 方法接受一个字符串参数,并返回加密后的字符串。
接下来是 C# 中的代码,用于解密数据:
```csharp
using System;
using System.Security.Cryptography;
using System.Text;
public class AesDecryption
{
private static readonly byte[] Key = Encoding.UTF8.GetBytes("0123456789abcdef"); // 16-byte key
private static readonly byte[] Iv = Encoding.UTF8.GetBytes("0123456789abcdef"); // 16-byte initialization vector
public static string Decrypt(string data)
{
byte[] encryptedData = Convert.FromBase64String(data);
using (Aes aes = Aes.Create())
{
aes.Key = Key;
aes.IV = Iv;
aes.Padding = PaddingMode.PKCS7;
aes.Mode = CipherMode.CBC;
ICryptoTransform decryptor = aes.CreateDecryptor(aes.Key, aes.IV);
byte[] decrypted = decryptor.TransformFinalBlock(encryptedData, 0, encryptedData.Length);
return Encoding.UTF8.GetString(decrypted);
}
}
}
```
这个代码使用了相同的 AES/CBC/PKCS5Padding 加密算法和 16 字节的密钥和初始化向量。`Decrypt()` 方法接受一个加密的字符串参数,并返回解密后的字符串。
使用这两个类,可以在 C# 和 Java 中进行 AES 加密和解密操作。注意,密钥和初始化向量需要在两种语言中保持一致。
用C#窗体实现AES加密和解密
首先,需要引入System.Security.Cryptography命名空间。
以下是C#窗体实现AES加密和解密的示例代码:
```
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
using System.Windows.Forms;
namespace AesDemo
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void btnEncrypt_Click(object sender, EventArgs e)
{
try
{
// 获取密钥和向量
string key = txtKey.Text.Trim();
string iv = txtIV.Text.Trim();
byte[] keyBytes = Encoding.UTF8.GetBytes(key);
byte[] ivBytes = Encoding.UTF8.GetBytes(iv);
// 获取明文
string plaintext = txtPlaintext.Text.Trim();
byte[] plaintextBytes = Encoding.UTF8.GetBytes(plaintext);
// 创建AES加密器
using (Aes aes = Aes.Create())
{
aes.Key = keyBytes;
aes.IV = ivBytes;
// 创建加密流
using (MemoryStream msEncrypt = new MemoryStream())
{
using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, aes.CreateEncryptor(), CryptoStreamMode.Write))
{
// 将明文写入加密流
csEncrypt.Write(plaintextBytes, 0, plaintextBytes.Length);
csEncrypt.FlushFinalBlock();
// 获取加密结果
byte[] ciphertextBytes = msEncrypt.ToArray();
string ciphertext = Convert.ToBase64String(ciphertextBytes);
// 显示加密结果
txtCiphertext.Text = ciphertext;
}
}
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
private void btnDecrypt_Click(object sender, EventArgs e)
{
try
{
// 获取密钥和向量
string key = txtKey.Text.Trim();
string iv = txtIV.Text.Trim();
byte[] keyBytes = Encoding.UTF8.GetBytes(key);
byte[] ivBytes = Encoding.UTF8.GetBytes(iv);
// 获取密文
string ciphertext = txtCiphertext.Text.Trim();
byte[] ciphertextBytes = Convert.FromBase64String(ciphertext);
// 创建AES解密器
using (Aes aes = Aes.Create())
{
aes.Key = keyBytes;
aes.IV = ivBytes;
// 创建解密流
using (MemoryStream msDecrypt = new MemoryStream(ciphertextBytes))
{
using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, aes.CreateDecryptor(), CryptoStreamMode.Read))
{
// 读取解密结果
byte[] plaintextBytes = new byte[ciphertextBytes.Length];
int bytesRead = csDecrypt.Read(plaintextBytes, 0, plaintextBytes.Length);
// 显示解密结果
string plaintext = Encoding.UTF8.GetString(plaintextBytes, 0, bytesRead);
txtPlaintext.Text = plaintext;
}
}
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
}
}
```
在窗体上添加三个TextBox控件和两个Button控件,分别命名为txtKey、txtIV、txtPlaintext、txtCiphertext、btnEncrypt和btnDecrypt。用户输入密钥、向量和明文,点击“加密”按钮进行加密,点击“解密”按钮进行解密。加密和解密过程中,采用AES算法进行加密和解密,使用Base64编码将密文转换为字符串。