class="brush:csharp;gutter:true;">using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.Cryptography;
using System.Text;
namespace ConsoleApp1
{
public class EncryptUtil
{
/// <summary>
/// MD5加密码字符串
/// </summary>
/// <param name="sInputString">消息体</param>
/// <returns>MD5签名字符</returns>
public static string MD5Encrypt(string sInputString)
{
System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
string encoded = BitConverter.ToString(md5.ComputeHash(Encoding.UTF8.GetBytes(sInputString))).Replace("-", "");
return encoded;
}
/// <summary>
/// DES加密
/// </summary>
/// <param name="sInputString">加密后的消息体</param>
/// <param name="sKey">24位的密钥</param>
/// <returns>解密后的消息体</returns>
public static string DESEncryptBase64(string sInputString, string sKey)
{
if (string.IsNullOrEmpty(sInputString) || string.IsNullOrEmpty(sKey) || sKey.Length != 24)
{
return string.Empty;
}
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
des.Mode = CipherMode.ECB;
des.Padding = PaddingMode.PKCS7;
string key = sKey.Substring(0, 12);
string iv = sKey.Remove(0, 12);
byte[] byKey = Convert.FromBase64String(key);
byte[] byIV = Convert.FromBase64String(iv);
byte[] inputByteArray = Encoding.UTF8.GetBytes(sInputString);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byKey, byIV), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
return Convert.ToBase64String(ms.ToArray());
}
/// <summary>
/// DES解密
/// </summary>
/// <param name="sInputString">待加密消息体</param>
/// <param name="sKey">24位的密钥</param>
/// <returns>加密后的消息体</returns>
public static string DESDecryptBase64(string sInputString, string sKey)
{
if (string.IsNullOrEmpty(sInputString) || string.IsNullOrEmpty(sKey) || sKey.Length != 24)
{
return string.Empty;
}
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
des.Mode = CipherMode.ECB;
des.Padding = PaddingMode.PKCS7;
string key = sKey.Substring(0, 12);
string iv = sKey.Remove(0, 12);
byte[] byKey = Convert.FromBase64String(key);
byte[] byIV = Convert.FromBase64String(iv);
byte[] inputByteArray = Convert.FromBase64String(sInputString);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(byKey, byIV), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
Encoding encoding = new UTF8Encoding();
return encoding.GetString(ms.ToArray());
}
}
}