base64.c
上传用户:xxcykj
上传日期:2007-01-04
资源大小:727k
文件大小:3k
源码类别:

Email客户端

开发平台:

Unix_Linux

  1. /*
  2.  * base64.c -- base-64 conversion routines.
  3.  *
  4.  * For license terms, see the file COPYING in this directory.
  5.  *
  6.  * This base 64 encoding is defined in RFC2045 section 6.8,
  7.  * "Base64 Content-Transfer-Encoding", but lines must not be broken in the
  8.  * scheme used here.
  9.  */
  10. #include "config.h"
  11. #include <ctype.h>
  12. static const char base64digits[] =
  13.    "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  14. #define BAD -1
  15. static const char base64val[] = {
  16.     BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD,
  17.     BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD,
  18.     BAD,BAD,BAD,BAD, BAD,BAD,BAD,BAD, BAD,BAD,BAD, 62, BAD,BAD,BAD, 63,
  19.      52, 53, 54, 55,  56, 57, 58, 59,  60, 61,BAD,BAD, BAD,BAD,BAD,BAD,
  20.     BAD,  0,  1,  2,   3,  4,  5,  6,   7,  8,  9, 10,  11, 12, 13, 14,
  21.      15, 16, 17, 18,  19, 20, 21, 22,  23, 24, 25,BAD, BAD,BAD,BAD,BAD,
  22.     BAD, 26, 27, 28,  29, 30, 31, 32,  33, 34, 35, 36,  37, 38, 39, 40,
  23.      41, 42, 43, 44,  45, 46, 47, 48,  49, 50, 51,BAD, BAD,BAD,BAD,BAD
  24. };
  25. #define DECODE64(c)  (isascii(c) ? base64val[c] : BAD)
  26. void to64frombits(unsigned char *out, const unsigned char *in, int inlen)
  27. /* raw bytes in quasi-big-endian order to base 64 string (NUL-terminated) */
  28. {
  29.     for (; inlen >= 3; inlen -= 3)
  30.     {
  31. *out++ = base64digits[in[0] >> 2];
  32. *out++ = base64digits[((in[0] << 4) & 0x30) | (in[1] >> 4)];
  33. *out++ = base64digits[((in[1] << 2) & 0x3c) | (in[2] >> 6)];
  34. *out++ = base64digits[in[2] & 0x3f];
  35. in += 3;
  36.     }
  37.     if (inlen > 0)
  38.     {
  39. unsigned char fragment;
  40.     
  41. *out++ = base64digits[in[0] >> 2];
  42. fragment = (in[0] << 4) & 0x30;
  43. if (inlen > 1)
  44.     fragment |= in[1] >> 4;
  45. *out++ = base64digits[fragment];
  46. *out++ = (inlen < 2) ? '=' : base64digits[(in[1] << 2) & 0x3c];
  47. *out++ = '=';
  48.     }
  49.     *out = '';
  50. }
  51. int from64tobits(char *out, const char *in)
  52. /* base 64 to raw bytes in quasi-big-endian order, returning count of bytes */
  53. {
  54.     int len = 0;
  55.     register unsigned char digit1, digit2, digit3, digit4;
  56.     if (in[0] == '+' && in[1] == ' ')
  57. in += 2;
  58.     if (*in == 'r')
  59. return(0);
  60.     do {
  61. digit1 = in[0];
  62. if (DECODE64(digit1) == BAD)
  63.     return(-1);
  64. digit2 = in[1];
  65. if (DECODE64(digit2) == BAD)
  66.     return(-1);
  67. digit3 = in[2];
  68. if (digit3 != '=' && DECODE64(digit3) == BAD)
  69.     return(-1); 
  70. digit4 = in[3];
  71. if (digit4 != '=' && DECODE64(digit4) == BAD)
  72.     return(-1);
  73. in += 4;
  74. *out++ = (DECODE64(digit1) << 2) | (DECODE64(digit2) >> 4);
  75. ++len;
  76. if (digit3 != '=')
  77. {
  78.     *out++ = ((DECODE64(digit2) << 4) & 0xf0) | (DECODE64(digit3) >> 2);
  79.     ++len;
  80.     if (digit4 != '=')
  81.     {
  82. *out++ = ((DECODE64(digit3) << 6) & 0xc0) | DECODE64(digit4);
  83. ++len;
  84.     }
  85. }
  86.     } while 
  87. (*in && *in != 'r' && digit4 != '=');
  88.     return (len);
  89. }
  90. /* base64.c ends here */