010-0002 Base64原理

 

一、编码规则
      Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个“=”。
例:将对ABC进行BASE64编码
        首先取ABC对应的ASCII码值。A(65)B(66)C(67)。
        再取二进制值A(01000001)B(01000010)C(01000011),然后把这三个字节的二进制码接起来(010000010100001001000011),再以6位为单位分成4个数据块并在最高位填充两个0后形成4个字节的编码后的值(00010000)(00010100)(00001001)(00000011)。蓝色部分为真实数据。再把这四个字节数据转化成10进制数得(16)(20)(19)(3)。最后根据BASE64给出的64个基本字符表,查出对应的ASCII码字符(Q)(U)(J)(D)。这里的值实际就是数据在字符表中的索引。
注BASE64字符表:ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/
二、解码规则
      解码过程就是把4个字节再还原成3个字节再根据不同的数据形式把字节数组重新整理成数据。
三、实现代码:

using System;
using System.IO;
using System.Data;
namespace Base64{
internal class Base64{
public static string Base64Code(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();
}


public static string Base64Decode(string Message){
if((Message.Length%4)!=0){
   throw new ArgumentException("不是正确的BASE64编码,请检查。","Message");
}
if(!System.Text.RegularExpressions.Regex.IsMatch(Message,"^[A-Z0-9/+=]*$",System.Text.RegularExpressions.RegexOptions.IgnoreCase)){
   throw new ArgumentException("包含不正确的BASE64编码,请检查。","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);
}
}

}

 

 

附录:

0     A        17    R        34    i        51    z
1     B        18    S        35    j        52    0
2     C        19    T        36    k        53    1
3     D        20    U        37    l        54    2
4     E        21    V        38    m        55    3
5     F        22    W        39    n        56    4
6     G        23    X        40    o        57    5
7     H        24    Y        41    p        58    6
8     I        25    Z        42    q        59    7
9     J        26    a        43    r        60    8
10    K        27    b        44    s        61    9
11    L        28    c        45    t        62    +
12    M        29    d        46    u        63    /
13    N        30    e        47    v
14    O        31    f        48    w        (pad) =
15    P        32    g        49    x
16    Q        33    h        50    y  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值