base64编码解码的实现(C语言)

原创 2002年04月16日 16:35:00

/****************************************************************
 This is a sample routine of base64 algorithm.The goal is to
 illustrate principles,so some details may be ignored.
 Author email:zhangwu2003@163.com
*****************************************************************/
#include <stdio.h>
#include <string.h>
#include <malloc.h>

char*  ch64="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

unsigned char *encode(unsigned char *src,int srclen)
{
 int n,buflen,i,j;
 int pading=0;
 unsigned char *buf;
 static unsigned char *dst; 

 buf=src;
 buflen=n=srclen;
 if(n%3!=0)  /* pad with '=' by using a temp buffer */
 {
  pading=1;
  buflen=n+3-n%3;
  buf=malloc(buflen+1);
  memset(buf,0,buflen+1);
  memcpy(buf,src,n);
  for(i=0;i<3-n%3;i++)
   buf[n+i]='=';
 }
 dst=malloc(buflen*4/3+1);
 memset(dst,0,buflen*4/3+1);
 for(i=0,j=0;i<buflen;i+=3,j+=4)
 {
  dst[j]=(buf[i]&0xFC)>>2;
  dst[j+1]=((buf[i]&0x03)<<4) + ((buf[i+1]&0xF0)>>4);
  dst[j+2]=((buf[i+1]&0x0F)<<2) + ((buf[i+2]&0xC0)>>6);
  dst[j+3]=buf[i+2]&0x3F; 
 }
 for(i=0;i<buflen*4/3;i++) /* map 6 bit value to base64 ASCII character */
  dst[i]=ch64[dst[i]];
 if(pading)
  free(buf);
 return dst;
}

unsigned char *decode(unsigned char *src)
{
 int n,i,j;
 unsigned char *p;
 static unsigned char *dst; 

 n=strlen(src);
 for(i=0;i<n;i++) /* map base64 ASCII character to 6 bit value */
 {
  p=strchr(ch64,src[i]);
  if(!p)
   break;
  src[i]=p-ch64;
 }
 dst=malloc(n*3/4+1);
 memset(dst,0,n*3/4+1);
 for(i=0,j=0;i<n;i+=4,j+=3)
 {
  dst[j]=(src[i]<<2) + ((src[i+1]&0x30)>>4);
  dst[j+1]=((src[i+1]&0x0F)<<4) + ((src[i+2]&0x3C)>>2);
  dst[j+2]=((src[i+2]&0x03)<<6) + src[i+3];
 }
 return dst;
}

void main()
{
// char *src="zhangwu张武";
 char src[]={'1','2','3',0,'a','b','*',0,'A','B','$'};
 unsigned char *dst1;
 unsigned char *dst2;
 unsigned int i;

 dst1=encode(src,11); /* the second parameter must accord with the first one */
 printf("%s/n",dst1);
 dst2=decode(dst1); 
 for(i=0;i<_msize(dst2);i++)
  printf("%c",dst2[i]);

 free(dst1);
 free(dst2);
}

Base64编码解码c语言实现

void Base64Encrypt(char *clearText_in, char *cipherText_out) {     char *p = clearText_in;     ch...
  • wayaoqiang
  • wayaoqiang
  • 2011年11月17日 15:15
  • 310

base64 编码解码 c语言实现

#include #include #include char *base64_encode(const char *src); char *base64_decode(const char ...
  • caiyunl
  • caiyunl
  • 2012年08月16日 20:11
  • 1157

Base64编码解码C语言实现

static const char *codes =    "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";  ...
  • yangbiaosmile
  • yangbiaosmile
  • 2014年06月28日 15:52
  • 911

C语言base64算法简单实现

用过一段大家常用的base64代码,老是多一位少一位弄不清楚,一狠心自己动手重写了一遍, 写完查找了其他网友实现的代码,才发现其实精品很多,既然写了就分享给可以用的上的朋友, 写代码就要写大家都能...
  • inreyou
  • inreyou
  • 2014年12月29日 15:02
  • 817

Base64编解码的C语言实现

Base64编码说明先简单的说明一下Base64的编码算法。Base64编码要求将3个8位字节(3*8=24)的数据转化为4个6位字节(4*6=24)的数据,之后在6位的前面填补两个0。当然需要编码的...
  • liyang051
  • liyang051
  • 2015年04月02日 11:04
  • 626

C语言实现Base64编解码

in_str是输入缓冲区的地址 in_len 要编码的数据的长度 out_str 输出的地址 需要在外面分配内存 unsigned char *out_str = (unsigned char *...
  • songjinshi
  • songjinshi
  • 2013年02月26日 16:56
  • 6230

Base64编码的C语言实现

本文转自http://blog.163.com/lixiangqiu_9202/blog/static/5357503720140593058179/ Bse64是一种以64个可打印字符对二进制数据...
  • abcdefg233
  • abcdefg233
  • 2016年10月23日 21:29
  • 1380

base64编码/解码的实现(C语言)

base64的作用不是加密,而是用来避免“字节”中不能转换成可显示字符的数值。 比如0-32的控制字符,空格,制表符都不能被打印在纸上,通过base64转换可以打印在纸上,数据可以在传统平面媒介上携...
  • rentiansheng
  • rentiansheng
  • 2013年11月30日 10:30
  • 2056

用C++实现Base64编码解码

Base64编码解码实现string Base64::EncodeBase64(char const * sourcebuf,int buflen) { string ret; uns...
  • xuzhouzhangzheng
  • xuzhouzhangzheng
  • 2015年06月15日 21:14
  • 190

Base64编码解码的实现(C语言)

base64编码解码的实现(C语言) /****************************************************************This is a sample...
  • iiprogram
  • iiprogram
  • 2008年04月18日 17:09
  • 411
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:base64编码解码的实现(C语言)
举报原因:
原因补充:

(最多只允许输入30个字)