博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Base64编码解码
阅读量:6673 次
发布时间:2019-06-25

本文共 2568 字,大约阅读时间需要 8 分钟。

what is base64 coding and decoding is in reference to

https://en.wikipedia.org/wiki/Base64

http://www.cnblogs.com/chengxiaohui/articles/3951129.html
  

//sample code in c++. Please note that the code needs refinements as there is some warning in some analysis tools,e.g. pc-lint, Coverity etc.

// it is just a sample code for study.

//declaration in header

std::string base64Encode(const std::vector<char>& byteData);

std::vector<char> base64Decode(std::string & const inputString);

 

//implemenation

std::string Cbase64Dlg::base64Encode(const std::vector<char>& byteData)

{
   const std::string codes = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
   std::string base64String;
   int b;
   for (size_t i = 0; i < byteData.size(); i = i+3)
   {
      b = (byteData[i] & 0xFC) >> 2;
      base64String.push_back(codes[b]);
      b = (byteData[i] & 0x03) << 4;
      if (i + 1 < byteData.size())
      {
         b |= (byteData[i + 1] & 0xF0) >> 4;
         base64String.push_back(codes[b]);
         b = (byteData[i + 1] & 0x0F) << 2;
         if (i+2 < byteData.size())
         {
            b |= (byteData[i + 2] & 0xC0) >> 6;
            base64String.push_back(codes[b]);
            b = byteData[i + 2] & 0x3F;
            base64String.push_back(codes[b]);
         }
         else
         {
            base64String.push_back(codes[b]);
            base64String.append("=");
         }
      }
      else
      {
         base64String.push_back(codes[b]);
         base64String.append("==");
      }
   }
   
   return base64String;
}
std::vector<char> Cbase64Dlg::base64Decode(std::string & const inputString)
{   
   static std::string codes = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
   std::vector<char> decoded;
   if (inputString.length() % 4 != 0)    
   {
      return std::vector<char>();
   }
   //The ratio of output bytes to input bytes is 4:3
   int outLen = (inputString.length() * 3 / 4);
   size_t pos = inputString.find_first_of('=');
   if (pos != std::string::npos)
   {
      decoded.resize(outLen - (inputString.length() - pos));
   }
   else
   {
      decoded.resize(outLen);
   }
   int j = 0;
   int b[4] = {};
   const char* p = inputString.c_str();
   while(p && *p && j < outLen)
   {
      bool valid = false;
      for (int i=0; p && i < 4; ++i)
      {
         size_t pos = codes.find_first_of(*p++);
         if ( pos != std::string::npos)
         {
            b[i] = pos;
         }
      }
      if (j < outLen)
      {
         decoded[j++] = (byte) ((b[0] << 2) | (b[1] >> 4));;
         if (j < outLen && b[2] < 64)      
         {
            decoded[j++] = (byte) ((b[1] << 4) | (b[2] >> 2));
            if (j < outLen && b[3] < 64)  
            {
               decoded[j++] = (byte) ((b[2] << 6) | b[3]);
            }
         }
      }
   }
   return decoded;
}

 

// test code

   char myints[] = "ABC&&&&&&&&&&";

   std::vector<char> byte (myints, myints + sizeof(myints) / sizeof(char) );
   std::string value = base64Encode(byte);
   std::cout << value << std::endl;
   std::vector<char>decode = base64Decode(value);

你可能感兴趣的文章
C C++ OC指针常量和常量指针区别
查看>>
前端异常监控 - BadJS
查看>>
nginx安装
查看>>
mysql函数大全
查看>>
tomcat内存溢出设置JAVA_OPTS
查看>>
[CareerCup] 12.5 Test a Pen 测试一支笔
查看>>
Codeforces Round #328 (Div. 2) B. The Monster and the Squirrel 打表数学
查看>>
需要学习的技术
查看>>
TMDS协议
查看>>
Spark应用程序运行的日志存在哪里(转)
查看>>
迭代算法与递归算法的概念及区别
查看>>
我对CSS vertical-align的一些理解与认识(一)
查看>>
离线安装谷歌扩展
查看>>
使用Maven搭建Struts2+Spring3+Hibernate4的整合开发环境
查看>>
Round() 四舍五入 js银行家算法
查看>>
hdu 5594 ZYB's Prime 最大流
查看>>
Android - HelloWorld的Layout内容
查看>>
#Linux学习笔记# Linux文件的所有者、群组和其他人
查看>>
最近反思
查看>>
java四舍五入的取舍
查看>>