【C#ソース】DES暗号解読クラス
7122 ワード
using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using System.Security.Cryptography;
using System.Collections;
namespace Deking
{
class DesEncryption
{
//
private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
/// <summary>
/// DES
/// </summary>
/// <param name="encryptString"> </param>
/// <param name="encryptKey"> , 8 </param>
/// <returns> , </returns>
public static string EncryptDES(string encryptString, string encryptKey)
{
try
{
byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
byte[] rgbIV = Keys;
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;
}
}
/// <summary>
/// DES
/// </summary>
/// <param name="decryptString"> </param>
/// <param name="decryptKey"> , 8 , </param>
/// <returns> , </returns>
public static string DecryptDES(string decryptString, string decryptKey)
{
try
{
byte[] rgbKey = Encoding.UTF8.GetBytes(decryptKey);
byte[] rgbIV = Keys;
byte[] inputByteArray = Convert.FromBase64String(decryptString);
DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Encoding.UTF8.GetString(mStream.ToArray());
}
catch
{
return decryptString;
}
}
}
public void DesEncrypt(string sInputFilename, string sOutputFilename, string key) //
{
string sKey;
FileStream fsInput = new FileStream(sInputFilename,
FileMode.Open,
FileAccess.Read);
FileStream fsEncrypted = new FileStream(sOutputFilename,
FileMode.Create,
FileAccess.Write);
DESCryptoServiceProvider DES = new DESCryptoServiceProvider();
if (key.Length >= 8)
sKey = key.Substring(0, 8);
else
{
sKey = key.PadRight(8, '1');
}
DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
ICryptoTransform desencrypt = DES.CreateEncryptor();
CryptoStream cryptostream = new CryptoStream(fsEncrypted,
desencrypt,
CryptoStreamMode.Write);
byte[] bytearrayinput = new byte[fsInput.Length];
fsInput.Read(bytearrayinput, 0, bytearrayinput.Length);
cryptostream.Write(bytearrayinput, 0, bytearrayinput.Length);
cryptostream.Close();
fsInput.Close();
fsEncrypted.Close();
System.IO.File.Delete(sInputFilename);
}
public void DesDecrypt(string sInputFilename,
string sOutputFilename,
string key)
{
string sKey;
DESCryptoServiceProvider DES = new DESCryptoServiceProvider();
//
// key 8
//
if (key.Length >= 8)
sKey = key.Substring(0, 8);
else
{
sKey = key.PadRight(8, '1');
}
DES.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
//Set initialization vector.
DES.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
FileStream fsread = new FileStream(sInputFilename,
FileMode.Open,
FileAccess.Read);
FileStream fswrite = new FileStream(sOutputFilename,
FileMode.Create,
FileAccess.Write);
ICryptoTransform desdecrypt = DES.CreateDecryptor();
CryptoStream cryptostreamDecr = new CryptoStream(fswrite,
desdecrypt,
CryptoStreamMode.Write);
byte[] bytearrayinput = new byte[fsread.Length];
fsread.Read(bytearrayinput, 0, bytearrayinput.Length);
cryptostreamDecr.Write(bytearrayinput, 0, bytearrayinput.Length);
cryptostreamDecr.Close();
fswrite.Close();
fsread.Close();
System.IO.File.Delete(sInputFilename);
}
}
}