少妇脱了内裤让我添,久久久久亚洲精品无码网址蜜桃,性色av免费观看,久久人妻av无码中文专区

分享

C語言實現Base64編碼解碼函數

 orion360doc 2011-08-30

C語言實現Base64編碼解碼函數

作者:aishen944      來源:zz     發表時間:2006-08-22     瀏覽次數: 42749      字號:    

 

/* *****************************************************************************

 * Description : BASE64 encoding and decoding

 * Date             : 06-08-21 21:00

 * Author          :  aishen944

 * Copryright   : 

********************************************************************************/

#include <string.h>
#include <stdlib.h>
#include <errno.h>

#define BASE64_PAD64 '='

char base64_alphabet[] = {'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', '+',
                          '/'};

char base64_suffix_map[256] = {
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255,  62, 255, 255, 255,  63,  52,  53,  54,  55,  56,  57,  58,  59,  60,  61, 255, 255,
     255, 255, 255, 255, 255,  0,   1,    2,   3,   4,   5,   6,   7,   8,   9,  10,  11,  12,  13,  14,
     15,   16,  17,  18,  19,  20,  21,  22,  23,  24,  25, 255, 255, 255, 255, 255, 255,  26,  27,  28,
     29,   30,  31,  32,  33,  34,  35,  36,  37,  38,  39,  40,  41,  42,  43,  44,  45,  46,  47,  48,
     49,   50,  51, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
     255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255};

static char cmove_bits(unsigned char src, unsigned lnum, unsigned rnum) {
   src <<= lnum;
   src >>= rnum;
   return src;
}

char* base64_encode(const char *data) {
   char *ret, *retpos;
   int n, m, padnum = 0, retsize, dlen = strlen(data);

   if(dlen == 0) return NULL;

   /* Account the result buffer size and alloc the memory for it. */
   if((dlen % 3) != 0)
    padnum = 3 - dlen % 3;
   retsize = (dlen + padnum) + ((dlen + padnum) * 1/3) + 1;
   if((ret = malloc(retsize)) == NULL) 
      return NULL;
   retpos = ret;

   /* Starting to convert the originality characters to BASE64 chracaters. 
      Converting process keep to 4->6 principle. */
   for(m = 0; m < (dlen + padnum); m += 3) {
      /* When data is not suffice 24 bits then pad 0 and the empty place pad '='. */
      *(retpos) = base64_alphabet[cmove_bits(*data, 0, 2)];
      if(m == dlen + padnum - 3 && padnum != 0) {  /* Whether the last bits-group suffice 24 bits. */
          if(padnum == 1) {   /* 16bit need pad one '='. */
              *(retpos + 1) = base64_alphabet[cmove_bits(*data, 6, 2) + cmove_bits(*(data + 1), 0, 4)];
              *(retpos + 2) = base64_alphabet[cmove_bits(*(data + 1), 4, 2)];
              *(retpos + 3) = BASE64_PAD64;
          } else if(padnum == 2) { /* 8bit need pad two'='. */
              *(retpos + 1) = base64_alphabet[cmove_bits(*data, 6, 2)];
              *(retpos + 2) = BASE64_PAD64;
              *(retpos + 3) = BASE64_PAD64;
          }
      } else {  /* 24bit normal. */
         *(retpos + 1) = base64_alphabet[cmove_bits(*data, 6, 2) + cmove_bits(*(data + 1), 0, 4)];
         *(retpos + 2) = base64_alphabet[cmove_bits(*(data + 1), 4, 2) + cmove_bits(*(data + 2), 0, 6)];
         *(retpos + 3) = base64_alphabet[*(data + 2) & 0x3f];
      }

      retpos += 4;
      data += 3;
   }

   ret[retsize - 1] =0;

   return ret;
}

char* base64_decode(const char *bdata) {
   char *ret = NULL, *retpos;
   int n, m, padnum = 0, retsize, bdlen = strlen(bdata);

   if(bdlen == 0) return NULL;
   if(bdlen % 4 != 0) return NULL;

   /* Whether the data have invalid base-64 characters? */
   for(m = 0; m < bdlen; ++m) {
      if(bdata[m] != BASE64_PAD64 && base64_suffix_map[bdata[m]] == 255)
         goto LEND;
   }

   /* Account the output size. */
   if(bdata[bdlen - 1] ==  '=')  padnum = 1;
   if(bdata[bdlen - 1] == '=' && bdata[bdlen - 2] ==  '=') padnum = 2;
   retsize = (bdlen - 4) - (bdlen - 4) / 4 + (3 - padnum) + 1;
   ret = malloc(retsize);
   if(ret == NULL) 
         return NULL;
   retpos = ret;

   /* Begging to decode. */
   for(m = 0; m < bdlen; m += 4) {
      *retpos = cmove_bits(base64_suffix_map[*bdata], 2, 0) + cmove_bits(base64_suffix_map[*(bdata + 1)], 0, 4);
      if(m == bdlen - 4 && padnum != 0) {  /* Only deal with last four bits. */
         if(padnum == 1)   /* Have one pad characters, only two availability characters. */
            *(retpos + 1) = cmove_bits(base64_suffix_map[*(bdata + 1)], 4, 0) + cmove_bits(base64_suffix_map[*(bdata + 2)], 0, 2);
         /*
         Have two pad characters, only two availability characters.
         if(padnum == 2) { 
         }
         */
         retpos += 3 - padnum;
      } else {
         *(retpos + 1) = cmove_bits(base64_suffix_map[*(bdata + 1)], 4, 0) + cmove_bits(base64_suffix_map[*(bdata + 2)], 0, 2);
         *(retpos + 2) = cmove_bits(base64_suffix_map[*(bdata + 2)], 6, 0) + base64_suffix_map[*(bdata + 3)];
         retpos += 3;
      }
      bdata += 4;
   }

   ret[retsize - 1] = 0;

   LEND: return ret;
}


 

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發布,不代表本站觀點。請注意甄別內容中的聯系方式、誘導購買等信息,謹防詐騙。如發現有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發表

    請遵守用戶 評論公約

    類似文章 更多

    主站蜘蛛池模板: 国产人妻精品无码av在线| 精品国产一区二区三区久久影院| 人妻激情偷乱一区二区三区| 亚洲精品国偷拍自产在线| 国产成人一卡2卡3卡四卡视频| 精品人妻系列无码专区久久| 日韩亚洲av无码一区二区不卡| 亚洲精品久久久av无码专区| 男女啪啪做爰高潮免费网站| 中文在线天堂网www| 亚洲国产精品一区二区成人片国内| 国精品无码一区二区三区左线| 在线观看亚洲精品国产福利片| 天天澡天天揉揉av无码| 黑人精品XXX一区一二区| 久久综合99re88久久爱| 免费精品国自产拍在线不卡| 无码中文人妻在线一区| 97久久天天综合色天天综合色hd| 无码熟妇人妻av影音先锋| 国产精品毛片无遮挡| 国产欧色美视频综合二区| 精品国产一二三产品区别在哪| 久9re热视频这里只有精品| 精品一区二区三区无码视频| 97一区二区国产好的精华液| 精品国产乱码久久久久久夜深人妻| 久久人人妻人人做人人爽| 亚洲色精品vr一区二区三区| 精品国产制服丝袜高跟| 天天躁日日躁狠狠躁av麻豆| 午夜成人精品福利网站在线观看| 欧美疯狂做受xxxx高潮小说| 亚洲综合无码明星蕉在线视频| 久久久久亚洲av无码专区网站| 变态拳头交视频一区二区| 国产免费看又黄又大又污的胸| 国产一区二区三区久久精品| 日韩欧美卡一卡二卡新区| 久久人妻公开中文字幕| 精品黑人一区二区三区久久|