Base64.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. #include "Base64.h"
  2. static const char *g_pCodes =
  3. "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
  4. static const unsigned char g_pMap[256] =
  5. {
  6. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  7. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  8. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  9. 255, 255, 255, 255, 255, 255, 255, 62, 255, 255, 255, 63,
  10. 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 255, 255,
  11. 255, 254, 255, 255, 255, 0, 1, 2, 3, 4, 5, 6,
  12. 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18,
  13. 19, 20, 21, 22, 23, 24, 25, 255, 255, 255, 255, 255,
  14. 255, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36,
  15. 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
  16. 49, 50, 51, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  17. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  18. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  19. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  20. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  21. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  22. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  23. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  24. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  25. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  26. 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
  27. 255, 255, 255, 255
  28. };
  29. CBase64::CBase64()
  30. {
  31. }
  32. CBase64::~CBase64()
  33. {
  34. }
  35. bool CBase64::Encode(const unsigned char *pIn, unsigned long uInLen, unsigned char *pOut, unsigned long *uOutLen)
  36. {
  37. unsigned long i, len2, leven;
  38. unsigned char *p;
  39. if(pOut == NULL || *uOutLen == 0)
  40. return false;
  41. //ASSERT((pIn != NULL) && (uInLen != 0) && (pOut != NULL) && (uOutLen != NULL));
  42. len2 = ((uInLen + 2) / 3) << 2;
  43. if((*uOutLen) < (len2 + 1)) return false;
  44. p = pOut;
  45. leven = 3 * (uInLen / 3);
  46. for(i = 0; i < leven; i += 3)
  47. {
  48. *p++ = g_pCodes[pIn[0] >> 2];
  49. *p++ = g_pCodes[((pIn[0] & 3) << 4) + (pIn[1] >> 4)];
  50. *p++ = g_pCodes[((pIn[1] & 0xf) << 2) + (pIn[2] >> 6)];
  51. *p++ = g_pCodes[pIn[2] & 0x3f];
  52. pIn += 3;
  53. }
  54. if (i < uInLen)
  55. {
  56. unsigned char a = pIn[0];
  57. unsigned char b = ((i + 1) < uInLen) ? pIn[1] : 0;
  58. unsigned char c = 0;
  59. *p++ = g_pCodes[a >> 2];
  60. *p++ = g_pCodes[((a & 3) << 4) + (b >> 4)];
  61. *p++ = ((i + 1) < uInLen) ? g_pCodes[((b & 0xf) << 2) + (c >> 6)] : '=';
  62. *p++ = '=';
  63. }
  64. *p = 0; // Append NULL byte
  65. *uOutLen = p - pOut;
  66. return true;
  67. }
  68. bool CBase64::Encode(const unsigned char *pIn, unsigned long uInLen, string& strOut)
  69. {
  70. unsigned long i, len2, leven;
  71. strOut = "";
  72. //ASSERT((pIn != NULL) && (uInLen != 0) && (pOut != NULL) && (uOutLen != NULL));
  73. len2 = ((uInLen + 2) / 3) << 2;
  74. //if((*uOutLen) < (len2 + 1)) return false;
  75. //p = pOut;
  76. leven = 3 * (uInLen / 3);
  77. for(i = 0; i < leven; i += 3)
  78. {
  79. strOut += g_pCodes[pIn[0] >> 2];
  80. strOut += g_pCodes[((pIn[0] & 3) << 4) + (pIn[1] >> 4)];
  81. strOut += g_pCodes[((pIn[1] & 0xf) << 2) + (pIn[2] >> 6)];
  82. strOut += g_pCodes[pIn[2] & 0x3f];
  83. pIn += 3;
  84. }
  85. if (i < uInLen)
  86. {
  87. unsigned char a = pIn[0];
  88. unsigned char b = ((i + 1) < uInLen) ? pIn[1] : 0;
  89. unsigned char c = 0;
  90. strOut += g_pCodes[a >> 2];
  91. strOut += g_pCodes[((a & 3) << 4) + (b >> 4)];
  92. strOut += ((i + 1) < uInLen) ? g_pCodes[((b & 0xf) << 2) + (c >> 6)] : '=';
  93. strOut += '=';
  94. }
  95. //*p = 0; // Append NULL byte
  96. //*uOutLen = p - pOut;
  97. return true;
  98. }
  99. bool CBase64::Decode(const string& strIn, vector<unsigned char> &strOut)
  100. {
  101. unsigned long t, x, y, z;
  102. unsigned char c;
  103. unsigned long g = 3;
  104. //ASSERT((pIn != NULL) && (uInLen != 0) && (pOut != NULL) && (uOutLen != NULL));
  105. for(x = y = z = t = 0; x < strIn.length(); x++)
  106. {
  107. c = g_pMap[strIn[x]];
  108. if(c == 255) continue;
  109. if(c == 254) { c = 0; g--; }
  110. t = (t << 6) | c;
  111. if(++y == 4)
  112. {
  113. strOut.push_back((unsigned char)((t>>16)&255));
  114. if(g > 1) strOut.push_back((unsigned char)((t>>8)&255));
  115. if(g > 2) strOut.push_back((unsigned char)(t&255));
  116. y = t = 0;
  117. }
  118. }
  119. return true;
  120. }
  121. bool CBase64::Decode(const string& strIn, string &strOut)
  122. {
  123. unsigned long t, x, y, z;
  124. unsigned char c;
  125. unsigned long g = 3;
  126. strOut = "";
  127. //ASSERT((pIn != NULL) && (uInLen != 0) && (pOut != NULL) && (uOutLen != NULL));
  128. for (x = y = z = t = 0; x < strIn.length(); x++)
  129. {
  130. c = g_pMap[strIn[x]];
  131. if (c == 255) continue;
  132. if (c == 254) { c = 0; g--; }
  133. t = (t << 6) | c;
  134. if (++y == 4)
  135. {
  136. strOut += ((unsigned char)((t >> 16) & 255));
  137. if (g > 1) strOut += ((unsigned char)((t >> 8) & 255));
  138. if (g > 2) strOut += ((unsigned char)(t & 255));
  139. y = t = 0;
  140. }
  141. }
  142. return true;
  143. }