DES对称加密算法
程序员文章站
2022-06-10 10:58:17
...
问题 A: DES对称加密算法
时间限制: 1 Sec 内存限制: 128 MB
提交: 190 解决: 155
[提交][状态][讨论版][命题人:201001000549]
题目描述
参考相关文献,设计一个DES对称加密算法。并编写一个控制台应用予以验证。**设定为:@1234567。
class Program{
//验证DES加密算法
static void Main(string[] args){
Console.WriteLine(Class1.ECP(“[email protected]&!”));
}
}
public class Class1 {
//下面ECP方法功能为采用对称加密算法
//该算法原理请大家百度
const string KEY_64 = "@1234567";
const string IV_64 = "@1234567";
public static string ECP(string data) {
//这里编写DES对称加密算法代码
}
输入
一个字符串
输出
加密后的字符串
样例输入
123456
样例输出
czgzz5i20Rw=
我也不是很懂,先放在这,有时间再看看吧
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Security.Cryptography;
using System.IO;
namespace ConsoleApp1
{
class Program
{
//验证DES加密算法
static void Main(string[] args)
{
string input = Console.ReadLine();
Console.WriteLine(Class1.strEncryptDES(input, "@1234567"));
Console.ReadKey();
}
}
public class Class1
{
public static string strEncryptDES(string encryptString, string encryptKey)
{
try
{
byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
byte[] rgbIV = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray());
}
catch
{
return encryptString;
}
}
}
}