首页 > 代码库 > C语言实现base64编码,base64解码
C语言实现base64编码,base64解码
char *base64_encode(char *binData, char *base64, int binLength) { int i = 0; int j = 0; int current = 0; for (i = 0; i < binLength; i += 3) { //获取第一个6位 current = (*(binData+i) >> 2) & 0x3F; *(base64 + j++) = base64char[current]; //获取第二个6位的前两位 current = (*(binData+i) << 4) & 0x30; //如果只有一个字符,那么需要做特殊处理 if (binLength <= (i+1)) { *(base64 + j++) = base64char[current]; *(base64 + j++) = ‘=‘; *(base64 + j++) = ‘=‘; break; } //获取第二个6位的后四位 current |= (*(binData+i+1) >> 4 ) & 0xf; *(base64 + j++) = base64char[current]; //获取第三个6位的前四位 current = (*(binData+i+1) << 2 ) & 0x3c; if (binLength <= (i+2)) { *(base64 + j++) = base64char[current]; *(base64 + j++) = ‘=‘; break; } //获取第三个6位的后两位 current |= (*(binData+i+2) >> 6) & 0x03; *(base64 + j++) = base64char[current]; //获取第四个6位 current = *(binData+i+2) & 0x3F; *(base64 + j++) = base64char[current]; } *(base64+j) = ‘\0‘; return base64; } char *base64_decode(char const *base64Str, char *debase64Str, int encodeStrLen) { int i = 0; int j = 0; int k = 0; char temp[4] = ""; for (i = 0; i < encodeStrLen; i += 4) { for (j = 0; j < 64 ; j++) { if (*(base64Str + i) == base64char[j]) { temp[0] = j; } } for (j = 0; j < 64 ; j++) { if (*(base64Str + i + 1) == base64char[j]) { temp[1] = j; } } for (j = 0; j < 64 ; j++) { if (*(base64Str + i + 2) == base64char[j]) { temp[2] = j; } } for (j = 0; j < 64 ; j++) { if (*(base64Str + i + 3) == base64char[j]) { temp[3] = j; } } *(debase64Str + k++) = ((temp[0] << 2) & 0xFC) | ((temp[1]>>4) & 0x03); if ( *(base64Str + i + 2) == ‘=‘ ) break; *(debase64Str + k++) = ((temp[1] << 4) & 0xF0) | ((temp[2]>>2) & 0x0F); if ( *(base64Str + i + 3) == ‘=‘ ) break; *(debase64Str + k++) = ((temp[2] << 6) & 0xF0) | (temp[3] & 0x3F); } return debase64Str; }
C语言实现base64编码,base64解码
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。