• 加密解密


    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);
    }

  • 相关阅读:
    javascript的window.open()具体解释
    Async.js解决Node.js操作MySQL的回调大坑
    入门--JTBC系统学习(1)
    Hadoop1.2.1 全然分布式集群搭建实操笔记
    Hessian原理与程序设计
    pycharm最新注册方法 pycharm最新激活方法 2016pycharm最新注册方法
    如何修改linux时间? 校正linux系统的时间
    python 内建函数 type() 和 isinstance() 介绍
    标准类型内建函数 str()和 repr() (及 `` 运算符) 简单介绍
    标准类型内建函数 cmp()介绍
  • 原文地址:https://www.cnblogs.com/dfsxh/p/1408476.html
Copyright © 2020-2023  润新知