文档库 最新最全的文档下载
当前位置:文档库 › C#加密解密终极方法

C#加密解密终极方法

?using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using System.Security.Cryptography;


namespace XiangleSystem
{
///


/// 加密解密类
///

public class EncryptSystem
{
///
/// 构造函数
///

public EncryptSystem()
{
//
}

///
/// 使用MD5不可逆加密算法加密字符串返回加密后的字符串
///

///
/// 需要加密的字符串
/// 加密后的字符串
public string MD5(string str)
{
byte[] bValue;
byte[] bHash;
string result = null;
MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();

bValue = System.Text.Encoding.UTF8.GetBytes(str);

bHash = https://www.wendangku.net/doc/7c309547.html,puteHash(bValue);

MD5.Clear();

for (int i = 0; i < bHash.Length; i++)
{
if (bHash[i].ToString("x").Length == 1)
{
//如果返回来是07这样的值,0会被省掉,所以强制加了一个0
result += "0" + bHash[i].ToString("x");
}
else
{
result += bHash[i].ToString("x");
}

}
return result.ToUpper();
}

///
/// 利用DES加密算法加密字符串(可解密)
///

/// 被加密的字符串
/// 密钥(只支持8个字节的密钥)
/// 加密后的字符串
public string Encrypt(string pToEncrypt, string sKey)
{
//访问数据加密标准(DES)算法的加密服务提供程序 (CSP) 版本的包装对象
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密对象的密钥和偏移量
des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); //原文使用ASCIIEncoding.ASCII方法的GetBytes方法


byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);//把字符串放到byte数组中

MemoryStream ms = new MemoryStream();//创建其支持存储区为内存的流
//定义将数据流链接到加密转换的流
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();

//上面已经完成了把加密后的结果放到内存中去
StringBuilder ret = new StringBuilder();
foreach (byte b in ms.ToArray())
{
ret.AppendFormat("{0:X2}", b);
}
ret.ToString();
return ret.ToString();
}

///


/// 利用DES解密算法解密密文(可解密)
///

/// 被解密的字符串
/// 密钥(只支持8个字节的密钥,同前面的加密密钥相同)
/// 返回被解密的字符串
public string Decrypt(string pToDecrypt, string sKey)
{
try
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();

byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
for (int x = 0; x < pToDecrypt.Length / 2; x++)
{
int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
inputByteArray[x] = (byte)i;
}

des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密对象的密钥和偏移量,此值重要,不能修改
des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);

cs.Write(inputByteArray, 0, inputByteArray.Length);

cs.FlushFinalBlock();

//建立StringBuild对象,createDecrypt使用的是流对象,必须把解密后的文本变成流对象
StringBuilder ret = new StringBuilder();

return System.Text.Encoding.Default.GetString(ms.ToArray());
}
catch (Exception)
{
return "error";
}
}

}
}

相关文档
相关文档 最新文档