实现BASE64加密、解密算法

C++

int CDB44Protocol::Base64Encode(char * base64code, const char * src, int src_len)

{

       if (src_len == 0)

              src_len = strlen(src);

      

       int len = 0;

       unsigned char* psrc = (unsigned char*)src;

       char * p64 = base64code;

       for (int i = 0; i < src_len - 3; i += 3)

       {

              unsigned long ulTmp = *(unsigned long*)psrc;

              register int _b0 = GetB64Char((B0(ulTmp) >> 2) & 0x3F);

              register int _b1 = GetB64Char((B0(ulTmp) << 6 >> 2 | B1(ulTmp) >> 4) & 0x3F);

              register int _b2 = GetB64Char((B1(ulTmp) << 4 >> 2 | B2(ulTmp) >> 6) & 0x3F);

              register int _b3 = GetB64Char((B2(ulTmp) << 2 >> 2) & 0x3F);

              *((unsigned long*)p64) = _b0 | _b1 << 8 | _b2 << 16 | _b3 << 24;

              len += 4;

              p64  += 4;

              psrc += 3;

       }

      

       // 处理最后余下的不足3字节的数据

       if (i < src_len)

       {

              int rest = src_len - i;

              unsigned long ulTmp = 0;

              for (int j = 0; j < rest; ++j)

              {

                     *(((unsigned char*)&ulTmp) + j) = *psrc++;

              }

             

              p64[0] = GetB64Char((B0(ulTmp) >> 2) & 0x3F);

              p64[1] = GetB64Char((B0(ulTmp) << 6 >> 2 | B1(ulTmp) >> 4) & 0x3F);

              p64[2] = rest > 1 ? GetB64Char((B1(ulTmp) << 4 >> 2 | B2(ulTmp) >> 6) & 0x3F) : '=';

              p64[3] = rest > 2 ? GetB64Char((B2(ulTmp) << 2 >> 2) & 0x3F) : '=';

              p64 += 4;

              len += 4;

       }

      

       *p64 = '\0';

      

       return len;

}

 

int CDB44Protocol::Base64Decode(char * buf, const char * base64code, int src_len)

{

       if (src_len == 0)

              src_len = strlen(base64code);

      

       int len = 0;

       unsigned char* psrc = (unsigned char*)base64code;

       char * pbuf = buf;

       for (int i = 0; i < src_len - 4; i += 4)

       {

              unsigned long ulTmp = *(unsigned long*)psrc;

             

              register int b0 = (GetB64Index((char)B0(ulTmp)) << 2 | GetB64Index((char)B1(ulTmp)) << 2 >> 6) & 0xFF;

              register int b1 = (GetB64Index((char)B1(ulTmp)) << 4 | GetB64Index((char)B2(ulTmp)) << 2 >> 4) & 0xFF;

              register int b2 = (GetB64Index((char)B2(ulTmp)) << 6 | GetB64Index((char)B3(ulTmp)) << 2 >> 2) & 0xFF;

             

              *((unsigned long*)pbuf) = b0 | b1 << 8 | b2 << 16;

              psrc  += 4;

              pbuf += 3;

              len += 3;

       }

      

       // 处理最后余下的不足4字节的饿数据

       if (i < src_len)

       {

              int rest = src_len - i;

              unsigned long ulTmp = 0;

              for (int j = 0; j < rest; ++j)

              {

                     *(((unsigned char*)&ulTmp) + j) = *psrc++;

              }

             

              register int b0 = (GetB64Index((char)B0(ulTmp)) << 2 | GetB64Index((char)B1(ulTmp)) << 2 >> 6) & 0xFF;

              *pbuf++ = b0;

              len  ++;

             

              if ('=' != B1(ulTmp) && '=' != B2(ulTmp))

              {

                     register int b1 = (GetB64Index((char)B1(ulTmp)) << 4 | GetB64Index((char)B2(ulTmp)) << 2 >> 4) & 0xFF;

                     *pbuf++ = b1;

                     len  ++;

              }

             

              if ('=' != B2(ulTmp) && '=' != B3(ulTmp))

              {

                     register int b2 = (GetB64Index((char)B2(ulTmp)) << 6 | GetB64Index((char)B3(ulTmp)) << 2 >> 2) & 0xFF;

                     *pbuf++ = b2;

                     len  ++;

              }

             

       }

      

       *pbuf = '\0';

      

       return len;

}

 

char CDB44Protocol::GetB64Char(int index)

{

       const char szBase64Table[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

       if (index >= 0 && index < 64)

              return szBase64Table[index];

      

       return '=';

}

 

int CDB44Protocol::GetB64Index(char ch)

{

       int index = -1;

       if (ch >= 'A' && ch <= 'Z')

       {

              index = ch - 'A';

       }

       else if (ch >= 'a' && ch <= 'z')

       {

              index = ch - 'a' + 26;

       }

       else if (ch >= '0' && ch <= '9')

       {

              index = ch - '0' + 52;

       }

       else if (ch == '+')

       {

              index = 62;

       }

       else if (ch == '/')

       {

              index = 63;

       }

      

       return index;

}

 

C#

 

/// <summary>

  /// Base64加密

  /// </summary>

  /// <param name="Message"></param>

  /// <returns></returns>

  public 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;

  //将字符分成3个字节一组,如果不足,则以0补齐

  int page = messageLen / 3;

  int use = 0;

  if ((use = messageLen % 3) > 0)

  {

  for (int i = 0; i < 3 - use; i++)

  byteMessage.Add(empty);

  page++;

  }

  //将3个字节的每组字符转换成4个字节一组的。3个一组,一组一组变成4个字节一组

  //方法是:转换成ASCII码,按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。

  outmessage = new System.Text.StringBuilder(page * 4);

  for (int i = 0; i < page; i++)

  {

  //取一组3个字节的组

  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];

  //六个位为一组,补0变成4个字节

  int[] outstr = new int[4];

  //第一个输出字节:取第一输入字节的前6位,并且在高位补0,使其变成8位(一个字节)

  outstr[0] = instr[0] >> 2;

  //第二个输出字节:取第一输入字节的后2位和第二个输入字节的前4位(共6位),并且在高位补0,使其变成8位(一个字节)

  outstr[1] = ((instr[0] & 0x03) << 4) ^ (instr[1] >> 4);

  //第三个输出字节:取第二输入字节的后4位和第三个输入字节的前2位(共6位),并且在高位补0,使其变成8位(一个字节)

  if (!instr[1].Equals(empty))

  outstr[2] = ((instr[1] & 0x0f) << 2) ^ (instr[2] >> 6);

  else

  outstr[2] = 64;

  //第四个输出字节:取第三输入字节的后6位,并且在高位补0,使其变成8位(一个字节)

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

  }

  /// <summary>

  /// Base64解密

  /// </summary>

  /// <param name="Message"></param>

  /// <returns></returns>

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

  }

  方法二:直接使用.NET中的的库类函数

  /// <summary>

  /// Base64加密

  /// </summary>

  /// <param name="Message"></param>

  /// <returns></returns>

  public string Base64Code(string Message)

  {

  byte[] bytes = Encoding.Default.GetBytes(Message);

  return Convert.ToBase64String(bytes);

  }

  /// <summary>

  /// Base64解密

  /// </summary>

  /// <param name="Message"></param>

  /// <returns></returns>

  public string Base64Decode(string Message)

  {

  byte[] bytes = Convert.FromBase64String(Message);

  return Encoding.Default.GetString(bytes);

  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值