技术文摘
C#中DES算法加密解密实例剖析
2025-01-02 02:42:55 小编
C#中DES算法加密解密实例剖析
在当今数字化时代,数据安全至关重要。加密算法作为保护数据隐私的关键技术,被广泛应用于各个领域。其中,DES(Data Encryption Standard)算法是一种对称加密算法,具有高效、可靠的特点。本文将通过一个C#实例来深入剖析DES算法的加密和解密过程。
我们需要了解DES算法的基本原理。DES算法使用相同的密钥进行加密和解密,它将数据分成64位的块,并通过一系列复杂的置换、替换和异或操作来实现加密。密钥长度为56位,加上8位的奇偶校验位,总共64位。
在C#中实现DES算法加密解密,需要使用System.Security.Cryptography命名空间下的相关类。以下是一个简单的示例代码:
using System;
using System.Security.Cryptography;
using System.Text;
class Program
{
static void Main()
{
string originalText = "Hello, World!";
string key = "12345678";
byte[] encryptedBytes = Encrypt(originalText, key);
string decryptedText = Decrypt(encryptedBytes, key);
Console.WriteLine("原始文本: " + originalText);
Console.WriteLine("加密后的数据: " + Convert.ToBase64String(encryptedBytes));
Console.WriteLine("解密后的文本: " + decryptedText);
}
static byte[] Encrypt(string plainText, string key)
{
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
des.Key = Encoding.UTF8.GetBytes(key);
des.IV = Encoding.UTF8.GetBytes(key);
using (ICryptoTransform encryptor = des.CreateEncryptor())
{
byte[] inputBytes = Encoding.UTF8.GetBytes(plainText);
return encryptor.TransformFinalBlock(inputBytes, 0, inputBytes.Length);
}
}
}
static string Decrypt(byte[] encryptedBytes, string key)
{
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
des.Key = Encoding.UTF8.GetBytes(key);
des.IV = Encoding.UTF8.GetBytes(key);
using (ICryptoTransform decryptor = des.CreateDecryptor())
{
byte[] decryptedBytes = decryptor.TransformFinalBlock(encryptedBytes, 0, encryptedBytes.Length);
return Encoding.UTF8.GetString(decryptedBytes);
}
}
}
}
在上述代码中,我们首先定义了原始文本和密钥。然后,通过Encrypt方法对原始文本进行加密,得到加密后的数据。最后,使用Decrypt方法对加密后的数据进行解密,恢复原始文本。
通过这个实例,我们可以看到DES算法在C#中的具体应用。在实际开发中,我们可以根据需求对代码进行进一步优化和扩展,以满足不同的安全需求。
- Nginx 配置里 root 与 alias 的差异及阐释
- Nginx 的跨域、别名与优化策略
- Linux 跨服务器文件传输操作指南
- Linux 中 ifconfig 命令无法查到 IP 的问题与解决之道
- Apache Kafka 实时数据处理应用的构建之道
- Tomcat 的 WebApps 与 ROOT 目录的差异及阐释
- Nginx 中 http 转换为 https 的操作流程
- 怎样更改 Tomcat 的默认 ROOT 目录
- Nginx 中 Map 模块的实际运用
- Tomcat 中 JMX 监控的全面解析
- Nginx 借助代理服务器实现目标接口访问
- nginx 服务器及版本号的隐藏实现
- Linux 虚拟机与主机互通的实现途径
- Tomcat 开机自启的多种设置方式(含无 service.bat 文件情形)
- idea 中缺失 tomcat 选项时的配置添加方法