Base64

一、编码规则
      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);
}
复制代码
复制代码

 

 
文章转自 http://www.cnblogs.com/yiki/archive/2009/01/18/1377828.html

转载于:https://www.cnblogs.com/Stacie/p/4903635.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值