1、方法一(不可逆加密)
publicstringEncryptPassword(stringPasswordString,stringPasswordFormat)
{
stringencryptPassword=null;
if(PasswordFormat="SHA1"){
encryptPassword=FormsAuthortication.HashPasswordForStoringInConfigFile(PasswordString
,"SHA1");
}
elseif(PasswordFormat="MD5")
{encryptPassword=FormsAuthortication.HashPasswordForStoringInConfigFile(PasswordString
,"MD5");
}
returnencryptPassword;
}
2、方法二(可逆加密)
publicinterfaceIBindesh
{
stringencode(stringstr);
stringdecode(stringstr);
}
publicclassEncryptionDecryption:IBindesh
{
publicstringencode(stringstr)
{
stringhtext="";
for(inti=0;i<str.Length;i++)
{
htext=htext+(char)(str[i]+10-1*2);
}
returnhtext;
}
publicstringdecode(stringstr)
{
stringdtext="";
for(inti=0;i<str.Length;i++)
{
dtext=dtext+(char)(str[i]-10+1*2);
}
returndtext;
}
3、方法三(可逆加密)
conststringKEY_64="VavicApp";//注意了,是8个字符,64位
conststringIV_64="VavicApp";
publicstringEncode(stringdata)
{
byte[]byKey=System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);
byte[]byIV=System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);
DESCryptoServiceProvidercryptoProvider=newDESCryptoServiceProvider();
inti=cryptoProvider.KeySize;
MemoryStreamms=newMemoryStream();
CryptoStreamcst=newCryptoStream(ms,cryptoProvider.CreateEncryptor(byKey,
byIV),CryptoStreamMode.Write);
StreamWritersw=newStreamWriter(cst);
sw.Write(data);
sw.Flush();
cst.FlushFinalBlock();
sw.Flush();
returnConvert.ToBase64String(ms.GetBuffer(),0,(int)ms.Length);
}
publicstringDecode(stringdata)
{
byte[]byKey=System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);
byte[]byIV=System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);
byte[]byEnc;
try
{
byEnc=Convert.FromBase64String(data);
}
catch
{
returnnull;
}
DESCryptoServiceProvidercryptoProvider=newDESCryptoServiceProvider();
MemoryStreamms=newMemoryStream(byEnc);
CryptoStreamcst=newCryptoStream(ms,cryptoProvider.CreateDecryptor(byKey,
byIV),CryptoStreamMode.Read);
StreamReadersr=newStreamReader(cst);
returnsr.ReadToEnd();
}
4、MD5不可逆加密
(32位加密)
publicstringGetMD5(strings,string_input_charset)
{
/**////<summary>
///与ASP兼容的MD5加密算法
///</summary>
MD5md5=newMD5CryptoServiceProvider();
byte[]t=md5.ComputeHash(Encoding.GetEncoding(_input_charset).GetBytes(s));
StringBuildersb=newStringBuilder(32);
for(inti=0;i<t.Length;i++)
{
sb.Append(t[i].ToString("x").PadLeft(2,'0'));
}
returnsb.ToString();
}
(16位加密)
publicstaticstringGetMd5Str(stringConvertString)
{
MD5CryptoServiceProvidermd5=newMD5CryptoServiceProvider();
stringt2=
BitConverter.ToString(md5.ComputeHash(UTF8Encoding.Default.GetBytes(ConvertString)),4,8);
t2=t2.Replace("-","");
returnt2;
}
5、加解文本文件
//加密文件
privatestaticvoidEncryptData(StringinName,StringoutName,byte[]desKey,byte[]
desIV)
{
//Createthefilestreamstohandletheinputandoutputfiles.
FileStreamfin=newFileStream(inName,FileMode.Open,FileAccess.Read);
FileStreamfout=newFileStream(outName,FileMode.OpenOrCreate,FileAccess.Write);
fout.SetLength(0);
//Createvariablestohelpwithreadandwrite.
byte[]bin=newbyte[100];//Thisisintermediatestoragefortheencryption.
longrdlen=0;//Thisisthetotalnumberofbyteswritten.
longtotlen=fin.Length;//Thisisthetotallengthoftheinputfile.
intlen;//Thisisthenumberofbytestobewrittenatatime.
DESdes=newDESCryptoServiceProvider();
CryptoStreamencStream=newCryptoStream(fout,des.CreateEncryptor(desKey,desIV),
CryptoStreamMode.Write);
//Readfromtheinputfile,thenencryptandwritetotheoutputfile.
while(rdlen<totlen)
{
len=fin.Read(bin,0,100);
encStream.Write(bin,0,len);
rdlen=rdlen+len;
}
encStream.Close();
fout.Close();
fin.Close();
}
//解密文件
privatestaticvoidDecryptData(StringinName,StringoutName,byte[]desKey,byte[]
desIV)
{
//Createthefilestreamstohandletheinputandoutputfiles.
FileStreamfin=newFileStream(inName,FileMode.Open,FileAccess.Read);
FileStreamfout=newFileStream(outName,FileMode.OpenOrCreate,FileAccess.Write);
fout.SetLength(0);
//Createvariablestohelpwithreadandwrite.
byte[]bin=newbyte[100];//Thisisintermediatestoragefortheencryption.
longrdlen=0;//Thisisthetotalnumberofbyteswritten.
longtotlen=fin.Length;//Thisisthetotallengthoftheinputfile.
intlen;//Thisisthenumberofbytestobewrittenatatime.
DESdes=newDESCryptoServiceProvider();
CryptoStreamencStream=newCryptoStream(fout,des.CreateDecryptor(desKey,desIV),
CryptoStreamMode.Write);
//Readfromtheinputfile,thenencryptandwritetotheoutputfile.
while(rdlen<totlen)
{
len=fin.Read(bin,0,100);
encStream.Write(bin,0,len);
rdlen=rdlen+len;
}
encStream.Close();
fout.Close();
fin.Close();
}
6、
usingSystem;
usingSystem.Collections.Generic;
usingSystem.Text;
usingSystem.Security.Cryptography;
usingSystem.IO;
namespaceComponent
{
publicclassSecurity
{
publicSecurity()
{
}
//默认密钥向量
privatestaticbyte[]Keys={0x12,0x34,0x56,0x78,0x90,0xAB,0xCD,0xEF};
/**//**//**////<summary>
///DES加密字符串
///</summary>
///<paramname="encryptString">待加密的字符串</param>
///<paramname="encryptKey">加密密钥,要求为8位</param>
///<returns>加密成功返回加密后的字符串,失败返回源串</returns>
publicstaticstringEncryptDES(stringencryptString,stringencryptKey)
{
try
{
byte[]rgbKey=Encoding.UTF8.GetBytes(encryptKey.Substring(0,8));
byte[]rgbIV=Keys;
byte[]inputByteArray=Encoding.UTF8.GetBytes(encryptString);
DESCryptoServiceProviderdCSP=newDESCryptoServiceProvider();
MemoryStreammStream=newMemoryStream();
CryptoStreamcStream=newCryptoStream(mStream,dCSP.CreateEncryptor(rgbKey,
rgbIV),CryptoStreamMode.Write);
cStream.Write(inputByteArray,0,inputByteArray.Length);
cStream.FlushFinalBlock();
returnConvert.ToBase64String(mStream.ToArray());
}
catch
{
returnencryptString;
}
}
/**//**//**////<summary>
///DES解密字符串
///</summary>
///<paramname="decryptString">待解密的字符串</param>
///<paramname="decryptKey">解密密钥,要求为8位,和加密密钥相同</param>
///<returns>解密成功返回解密后的字符串,失败返源串</returns>
publicstaticstringDecryptDES(stringdecryptString,stringdecryptKey)
{
try
{
byte[]rgbKey=Encoding.UTF8.GetBytes(decryptKey);
byte[]rgbIV=Keys;
byte[]inputByteArray=Convert.FromBase64String(decryptString);
DESCryptoServiceProviderDCSP=newDESCryptoServiceProvider();
MemoryStreammStream=newMemoryStream();
CryptoStreamcStream=newCryptoStream(mStream,DCSP.CreateDecryptor(rgbKey,
rgbIV),CryptoStreamMode.Write);
cStream.Write(inputByteArray,0,inputByteArray.Length);
cStream.FlushFinalBlock();
returnEncoding.UTF8.GetString(mStream.ToArray());
}
catch
{
returndecryptString;
}
}
}
}
分享到:
相关推荐
c#加密解密c#加密解密c#加密解密c#加密解密c#加密解密c#加密解密c#加密解密c#加密解密
c#加密解密类源码 全部代码 送上 .net c#版本
C#加密 解密对接java 的加密AES/CBC/PKCS7Padding 转16进制 C#加密解密中的详细整理
带加密字符的 加密 解密方法 static string encryptKey = "加密... 自定义加密字符(加密解密必须一致才能解密) /// /// 加密字符串 /// /// name="str">要加密的字符串 /// 加密后的字符串
c#加密解密加密解密加密解密加密解密加密解密c#加密解密加密解密加密解密加密解密加密解密
C#加密解密,包括DES、MD5、SHA256
java c# 加密解密
C#编写的加密解密小工具,可以对DES、RSA、Base64、SHA、MD5算法,轻松实现数据加密解密需求。 使用方法可浏览博文《C#集成数据加密算法,包含DES、RSA、Base64、SHA、MD5算法,轻松实现数据加密解密需求》
用c#做的加密解密的小软件,可以实现对文本的加密解密。
C# 加密解密 将自己的文件加密 //选择加密、解密文件 private void button1_Click(object sender, EventArgs e) { if (openFileDialog1.ShowDialog() == DialogResult.OK) { textBox1.Text = openFileDialog1....
asp.net C#的字符串加密解密类及说明.避免数据库密码明文保存. 好东西大家分享.
C#加密解密的函数参考 ,数据库加密与解密
C# 加密解密算法
C# 加密解密类,可以直接附加到程序中运行,已经很完善了
主要实现了对加密后的数据进行解密,对需要加密的数据加密,软件方便,简单,易用
附件是自己编写的加密和解密组件,以及测试程序源码,相同原文,每次加密后的密文都不一样,但是解密后仍然可以...原文可以是中英文混合,加密解密效率非常高,附件自带加密解密组件(KWEncrypt.DLL),可以在其他项目中放心使用
C# TripleDES MD5 里面将加密解密做成DLL类,再通过一个Winfrom去实现,Visual Studio 2008编译
c#加密解密工具类 C# 加密 解密 md5 aes
C# 加密解密数据 程序源码 支持自定义加密解密的密钥,帮助我们实现数据库连接字符串和用户密码的保密!