C# DES 加密解密类

// 名称空间  
using   System;  
using   System.Security.Cryptography;  
using   System.IO;  
using   System.Text;  

// 方法  
// 加密方法  
public      string   Encrypt( string   pToEncrypt,   string   sKey)  
{  
           DESCryptoServiceProvider  des  
=  new  DESCryptoServiceProvider();  
           
//把字符串放到byte数组中  
                 
//原来使用的UTF8编码,我改成Unicode编码了,不行  
           byte[]  inputByteArray  =  Encoding.Default.GetBytes(pToEncrypt);  
           
//byte[]  inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);  

           
//建立加密对象的密钥和偏移量  
           
//原文使用ASCIIEncoding.ASCII方法的GetBytes方法  
           
//使得输入密码必须输入英文文本  
           des.Key  =  ASCIIEncoding.ASCII.GetBytes(sKey);  
           des.IV  
=  ASCIIEncoding.ASCII.GetBytes(sKey);  
           MemoryStream  ms  
=  new  MemoryStream();  
           CryptoStream  cs  
=  new  CryptoStream(ms,  des.CreateEncryptor(),CryptoStreamMode.Write);  
           
//Write  the  byte  array  into  the  crypto  stream  
           
//(It  will  end  up  in  the  memory  stream)  
           cs.Write(inputByteArray,  0,  inputByteArray.Length);  
           cs.FlushFinalBlock();  
           
//Get  the  data  back  from  the  memory  stream,  and  into  a  string  
           StringBuilder  ret  =  new  StringBuilder();  
           
foreach(byte  b  in  ms.ToArray())  
                       
{  
                       
//Format  as  hex  
                       ret.AppendFormat("{0:X2}",  b);  
                       }
  
           ret.ToString();  
           
return  ret.ToString();  
}
  

// 解密方法  
public      string   Decrypt( string   pToDecrypt,   string   sKey)  
{  
           DESCryptoServiceProvider  des  
=  new  DESCryptoServiceProvider();  

           
//Put  the  input  string  into  the  byte  array  
           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);  
           
//Flush  the  data  through  the  crypto  stream  into  the  memory  stream  
           cs.Write(inputByteArray,  0,  inputByteArray.Length);  
           cs.FlushFinalBlock();  

           
//Get  the  decrypted  data  back  from  the  memory  stream  
           
//建立StringBuild对象,CreateDecrypt使用的是流对象,必须把解密后的文本变成流对象  
           StringBuilder  ret  =  new  StringBuilder();  
             
           
return  System.Text.Encoding.Default.GetString(ms.ToArray());  
}
  

来源:http://blog.csdn.net/keyu23/archive/2005/09/27/490577.aspx


using  System; 
using  System.IO; 
using  System.Text; 
using  System.Security.Cryptography; 
using  System.Web; 
namespace  Test.Com 

/**//// <summary> 
/// DESEncryptor 的摘要说明。 
/// </summary> 

public class DESEncryptor 

私有成员#region 私有成员 
/**//// <summary> 
/// 输入字符串 
/// </summary> 

private string inputString=null
/**//// <summary> 
/// 输出字符串 
/// </summary> 

private string outString=null
/**//// <summary> 
/// 输入文件路径 
/// </summary> 

private string inputFilePath=null
/**//// <summary> 
/// 输出文件路径 
/// </summary> 


中国3S吧 3s8.cn


private string outFilePath=null
/**//// <summary> 
/// 加密密钥 
/// </summary> 

private string encryptKey=null
/**//// <summary> 
/// 解密密钥 
/// </summary> 

private string decryptKey=null
/**//// <summary> 
/// 提示信息 
/// </summary> 

private string noteMessage=null
#endregion
 
公共属性#region 公共属性 
/**//// <summary> 
/// 输入字符串 
/// </summary> 

public string InputString 

get{return inputString;} 
set{inputString=value;} 
}
 
/**//// <summary> 
/// 输出字符串 
/// </summary> 

public string OutString 

get{return outString;} 
set{outString=value;} 
}
 
/**//// <summary> 
/// 输入文件路径 
/// </summary> 

public string InputFilePath 

get{return inputFilePath;} 
set{inputFilePath=value;} 
}
 
/**//// <summary> 
/// 输出文件路径 
/// </summary> 

中国3S吧 3s8.cn


public string OutFilePath 

get{return outFilePath;} 
set{outFilePath=value;} 
}
 
/**//// <summary> 
/// 加密密钥 
/// </summary> 

public string EncryptKey 

get{return encryptKey;} 
set{encryptKey=value;} 
}
 
/**//// <summary> 
/// 解密密钥 
/// </summary> 

public string DecryptKey 

get{return decryptKey;} 
set{decryptKey=value;} 
}
 
/**//// <summary> 
/// 错误信息 
/// </summary> 

public string NoteMessage 

get{return noteMessage;} 
set{noteMessage=value;} 
}
 
#endregion
 
构造函数#region 构造函数 
public DESEncryptor() 

// 
// TODO: 在此处添加构造函数逻辑 
// 
}
 
#endregion
 
DES加密字符串#region DES加密字符串 
/**//// <summary> 
/// 加密字符串 
/// 注意:密钥必须为8位 
/// </summary> 
/// <param name="strText">字符串</param> 
/// <param name="encryptKey">密钥</param> 

中国3S吧 3s8.cn

public void DesEncrypt() 

byte[] byKey=null
byte[] IV= {0x120x340x560x780x900xAB0xCD0xEF}
try 

byKey 
= System.Text.Encoding.UTF8.GetBytes(this.encryptKey.Substring(0,8)); 
DESCryptoServiceProvider des 
= new DESCryptoServiceProvider(); 
byte[] inputByteArray = Encoding.UTF8.GetBytes(this.inputString); 
MemoryStream ms 
= new MemoryStream(); 
CryptoStream cs 
= new CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write) ; 
cs.Write(inputByteArray, 
0, inputByteArray.Length); 
cs.FlushFinalBlock(); 
this.outString=Convert.ToBase64String(ms.ToArray()); 
}
 
catch(System.Exception error) 

this.noteMessage=error.Message; 
}
 
}
 
#endregion
 
DES解密字符串#region DES解密字符串 
/**//// <summary> 
/// 解密字符串 
/// </summary> 
/// <param name="this.inputString">加了密的字符串</param> 
/// <param name="decryptKey">密钥</param>  

public void DesDecrypt() 

byte[] byKey = null
byte[] IV= {0x120x340x560x780x900xAB0xCD0xEF}
byte[] inputByteArray = new Byte[this.inputString.Length]; 
try 

byKey 
= System.Text.Encoding.UTF8.GetBytes(decryptKey.Substring(0,8)); 
DESCryptoServiceProvider des 
= new DESCryptoServiceProvider(); 
inputByteArray 
= Convert.FromBase64String(this.inputString); 
MemoryStream ms 
= new MemoryStream(); 
CryptoStream cs 
= new CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write); 
cs.Write(inputByteArray, 
0, inputByteArray.Length); 
cs.FlushFinalBlock(); 
System.Text.Encoding encoding 
= new System.Text.UTF8Encoding(); 
this.outString=encoding.GetString(ms.ToArray()); 
}
 
catch(System.Exception error) 

this.noteMessage=error.Message; 
}
 
}
 
#endregion
 
DES加密文件#region DES加密文件 
/**//// <summary> 
/// DES加密文件 
/// </summary> 
/// <param name="this.inputFilePath">源文件路径</param> 



/// <param name="this.outFilePath">输出文件路径</param> 
/// <param name="encryptKey">密钥</param> 

public void FileDesEncrypt() 

byte[] byKey=null
byte[] IV= {0x120x340x560x780x900xAB0xCD0xEF}
try 

byKey 
= System.Text.Encoding.UTF8.GetBytes(this.encryptKey.Substring(0,8)); 
FileStream fin 
= new FileStream(this.inputFilePath, FileMode.Open, FileAccess.Read); 
FileStream fout 
= new FileStream(this.outFilePath, FileMode.OpenOrCreate, FileAccess.Write); 
fout.SetLength(
0); 
//Create variables to help with read and write. 
byte[] bin = new byte[100]; //This is intermediate storage for the encryption. 
long rdlen = 0//This is the total number of bytes written. 
long totlen = fin.Length; //This is the total length of the input file. 
int len; //This is the number of bytes to be written at a time. 
DES des = new DESCryptoServiceProvider(); 
CryptoStream encStream 
= new CryptoStream(fout, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write); 



//Read from the input file, then encrypt and write to the output file. 
while(rdlen < totlen) 

len 
= fin.Read(bin, 0100); 
encStream.Write(bin, 
0, len); 
rdlen 
= rdlen + len; 
}
 

中国3S吧 3s8.cn

encStream.Close(); 
fout.Close(); 
fin.Close(); 中国3S吧 3s8.cn 


}
 
catch(System.Exception error) 

this.noteMessage=error.Message.ToString(); 




}
 
}
 
#endregion
 
DES解密文件#region DES解密文件 
/**//// <summary> 
/// 解密文件 
/// </summary> 
/// <param name="this.inputFilePath">加密了的文件路径</param> 
/// <param name="this.outFilePath">输出文件路径</param> 
/// <param name="decryptKey">密钥</param> 

public void FileDesDecrypt() 

byte[] byKey = null
byte[] IV= {0x120x340x560x780x900xAB0xCD0xEF}
try 

byKey 
= System.Text.Encoding.UTF8.GetBytes(decryptKey.Substring(0,8)); 
FileStream fin 
= new FileStream(this.inputFilePath, FileMode.Open, FileAccess.Read); 
FileStream fout 
= new FileStream(this.outFilePath, FileMode.OpenOrCreate, FileAccess.Write); 
fout.SetLength(
0); 
//Create variables to help with read and write. 
byte[] bin = new byte[100]; //This is intermediate storage for the encryption. 
long rdlen = 0//This is the total number of bytes written.  
long totlen = fin.Length; //This is the total length of the input file. 
int len; //This is the number of bytes to be written at a time. 
DES des = new DESCryptoServiceProvider(); 
CryptoStream encStream 
= new CryptoStream(fout, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write);  


//Read from the input file, then encrypt and write to the output file. 
while(rdlen < totlen) 

len 
= fin.Read(bin, 0100); 
encStream.Write(bin, 
0, len); 
rdlen 
= rdlen + len; 
}
 中国3S吧 3s8.cn 

encStream.Close(); 
fout.Close(); 
fin.Close(); 
}
 
catch(System.Exception error) 

this.noteMessage=error.Message.ToString(); 
}
 
}
 
#endregion
 
MD5#region MD5 
/**//// <summary> 
/// MD5 Encrypt 
/// </summary> 
/// <param name="strText">text</param> 
/// <returns>md5 Encrypt string</returns> 

public void MD5Encrypt() 

MD5 md5 
= new MD5CryptoServiceProvider(); 
byte[] result = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(this.inputString)); 
this.outString=System.Text.Encoding.Default.GetString(result); 
}
 
#endregion
 




}
 
}
 


来源:  http://www.3s8.cn/develop/c1/200611/324.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值