加密解密

1、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());  
}
  




 

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

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

public class DESEncryptor 

私有成员 
公共属性 
构造函数 
DES加密字符串 
DES解密字符串 
DES加密文件 
DES解密文件 
MD5 




}
 
}
 

 

2、Bese64

一、编码规则
      Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节

数组。以3个字节为一组。按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前

补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是

3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在

结尾添加1到2个 “=”。

例:将对ABC进行BASE64编码:


1、首先取ABC对应的ASCII码值。A(65)B(66)C(67);
2、再取二进制值A(01000001)B(01000010)C(01000011);
 3、然后把这三个字节的二进制码接起来(010000010100001001000011);
4、 再以6位为单位分成4个数据块,并在最高位填充两个0后形成4个字节的编码后的值,(00010000)(00010100

)(00001001)(00000011),其中蓝色部分为真实数据;
 5、再把这四个字节数据转化成10进制数得(16)(20)(9)(3);
 6、最后根据BASE64给出的64个基本字符表,查出对应的ASCII码字符(Q)(U)(J)(D),这里的值实际就是

数据在字符表中的索引。

注:BASE64字符表:ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/

二、解码规则
      解码过程就是把4个字节再还原成3个字节再根据不同的数据形式把字节数组重新整理成数据。

三、C#中的实现

 

private string Encode64(string Message)
{
    
char[] Base64Code = new char
[]
      
{
        
'A''B''C''D''E''F''G''H''I''J''K''L''M''N'
,
          
'O''P''Q''R''S''T''U''V''W''X''Y''Z''a''b'
,
          
'c''d''e''f''g''h''i''j''k''l''m''n''o''p'
,
          
'q''r''s''t''u''v''w''x''y''z''0''1''2''3'
,
          
'4''5''6''7''8''9''+''/''='

      }
;
    
byte empty = (byte)0
;
    System.Collections.ArrayList byteMessage 
= new

      System.Collections.ArrayList(System.Text.Encoding.Default.GetBytes
      (Message));
    System.Text.StringBuilder outmessage;
    
int messageLen = byteMessage.Count;
    
int page = messageLen / 3
;
    
int use = 0
;
    
if ((use = messageLen % 3> 0
)
    
{
        
for (int i = 0; i < 3 - use; i++
)
            byteMessage.Add(empty);
        page
++
;
    }

    outmessage 
= new System.Text.StringBuilder(page * 4);
    
for (int i = 0; i < page; i++
)
    
{
        
byte[] instr = new byte[3
];
        instr[
0= (byte)byteMessage[i * 3
];
        instr[
1= (byte)byteMessage[i * 3 + 1
];
        instr[
2= (byte)byteMessage[i * 3 + 2
];
        
int[] outstr = new int[4
];
        outstr[
0= instr[0>> 2
;
        outstr[
1= ((instr[0& 0x03<< 4^ (instr[1>> 4
);
        
if (!instr[1
].Equals(empty))
            outstr[
2= ((instr[1& 0x0f<< 2^ (instr[2>> 6
);
        
else

            outstr[
2= 64;
        
if (!instr[2
].Equals(empty))
            outstr[
3= (instr[2& 0x3f
);
        
else

            outstr[
3= 64;
        outmessage.Append(Base64Code[outstr[
0
]]);
        outmessage.Append(Base64Code[outstr[
1
]]);
        outmessage.Append(Base64Code[outstr[
2
]]);
        outmessage.Append(Base64Code[outstr[
3
]]);
    }

    
return outmessage.ToString();
}


private string Decode64(string Message)
{
  
string Base64Code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="
;
  
int page = Message.Length / 4
;
  System.Collections.ArrayList outMessage 
= new System.Collections.ArrayList(page * 3
);
  
char[]message =
 Message.ToCharArray();
  
for (int i = 0; i < page; i++
)
  
{
    
byte[]instr = new byte[4
];
    instr[
0= (byte)Base64Code.IndexOf(message[i * 4
]);
    instr[
1= (byte)Base64Code.IndexOf(message[i * 4+1
]);
    instr[
2= (byte)Base64Code.IndexOf(message[i * 4+2
]);
    instr[
3= (byte)Base64Code.IndexOf(message[i * 4+3
]);
    
byte[]outstr = new byte[3
];
    outstr[
0= (byte)((instr[0<< 2^ ((instr[1& 0x30>> 4
));
    
if (instr[2!= 64
)
    
{
      outstr[
1= (byte)((instr[1<< 4^ ((instr[2& 0x3c>> 2
));
    }

    
else
    
{
      outstr[
2= 0
;
    }

    
if (instr[3!= 64)
    
{
      outstr[
2= (byte)((instr[2<< 6^ instr[3
]);
    }

    
else
    
{
      outstr[
2= 0
;
    }

    outMessage.Add(outstr[
0]);
    
if (outstr[1!= 0
)
      outMessage.Add(outstr[
1
]);
    
if (outstr[2!= 0
)
      outMessage.Add(outstr[
2
]);
  }

  
byte[]outbyte = (byte[])outMessage.ToArray(Type.GetType("System.Byte"));
  
return
 System.Text.Encoding.Default.GetString(outbyte);
}

 

 

 

 

posted @ 2009-03-11 10:15  林台山人  阅读(326)  评论(0编辑  收藏  举报