一个可逆的DES和TripleDES方式加密类(downmoon原创)

王朝other·作者佚名  2007-01-31
窄屏简体版  字體: |||超大  

一个可逆的DES和TripleDES方式加密类(downmoon原创)

using System;

using System.Security;

using System.Security.Cryptography;

using System.IO;

using System.Text;

namespace EncryptDownmoon

...{

/**//// <summary>

/// EncryptSqlConn 的摘要说明。

/// </summary>

public class EncryptSqlConn

...{

public EncryptSqlConn()

...{

if(mCSP ==null)

...{

mCSP = SetEnc();

}

}

/**//// <summary>

/// 设置加密方式,0为DES,1为TripleDES

/// </summary>

/// <returns></returns>

public EncryptSqlConn(int EnMethod)

...{

if(EnMethod==0)

...{

lngEnMethod=0;

}

else

...{

lngEnMethod=1;

}

if(mCSP ==null)

...{

mCSP = SetEnc();

}

}

方法#region 方法

private SymmetricAlgorithm mCSP;

private int m_lngEnMethod=0;

/**//// <summary>

/// 加密方式,0为DES,1为TripleDES

/// </summary>

public int lngEnMethod

...{

get

...{

return m_lngEnMethod;

}

set

...{

m_lngEnMethod=value;

}

}

private SymmetricAlgorithm SetEnc()

...{

if(lngEnMethod==0)

...{

return new DESCryptoServiceProvider();

}

else

return new TripleDESCryptoServiceProvider();

}

//测试键值

private string genKeyValue

...{

get

...{

mCSP.GenerateKey();

return Convert.ToBase64String(mCSP.Key);

}

}

//测试IV值

private string genIVValue

...{

get

...{

mCSP.GenerateIV();

return Convert.ToBase64String(mCSP.IV);

}

}

/**//// <summary>

/// 加密字串

/// </summary>

/// <param name="Value"></param>

/// <returns></returns>

public string EncryptString(string Value)

...{

ICryptoTransform ct;

MemoryStream ms;

CryptoStream cs;

byte[] byt;

ct = mCSP.CreateEncryptor(mCSP.Key, mCSP.IV);

//ct = mCSP.CreateEncryptor(genKeyValue,genIVValue);

byt = Encoding.UTF8.GetBytes(Value);

ms = new MemoryStream();

cs = new CryptoStream(ms, ct, CryptoStreamMode.Write);

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

cs.FlushFinalBlock();

cs.Close();

return Convert.ToBase64String(ms.ToArray());

}

/**//// <summary>

/// 解密字串

/// </summary>

/// <param name="Value"></param>

/// <returns></returns>

public string DecryptString(string Value)

...{

ICryptoTransform ct;

MemoryStream ms;

CryptoStream cs;

byte[] byt;

ct = mCSP.CreateDecryptor(mCSP.Key, mCSP.IV);

//ct = mCSP.CreateDecryptor(genKeyValue, genIVValue);

byt = Convert.FromBase64String(Value);

ms = new MemoryStream();

cs = new CryptoStream(ms, ct, CryptoStreamMode.Write);

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

cs.FlushFinalBlock();

cs.Close();

return Encoding.UTF8.GetString(ms.ToArray());

}

#endregion

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航