Linux C语言对图片进行Base64编码

一、编码规则
      Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个 “=”。

以下为Base64编码表:

码值字符码值字符码值字符码值字符
0A16Q32g48w
1B17R33h49x
2C18S34i50y
3D19T35j51z

4

E20U36k520
5F21V37l531
6G22W38m542
7H23X39n553
8I24Y40o564
9J25Z41p575
10K26a42q586
11L27b43r597
12M28c44s608
13N29d45t619
14O30e46u62+
15P31f47v63/

 例如:将对ABC进行Base64编码:

1、首先取ABC对应的ASCII码值。A(65)B(66)C(67);
2、再取二进制值A(01000001)B(01000010)C(01000011);
3、然后把这三个字节的二进制码接起来(010000010100001001000011);
4、 再以6位为单位分成4个数据块,并在最高位填充两个0后形成4个字节的编码后的值,(00010000)(00010100)(00001001)(00000011),其中蓝色部分为真实数据;
5、再把这四个字节数据转化成10进制数得(16)(20)(9)(3);
6、最后根据BASE64给出的64个基本字符表,查出对应的ASCII码字符(Q)(U)(J)(D),这里的值实际就是数据在字符表中的索引。

以下为实验代码:

char *inBase64Encode( const unsigned char * inBindata, char * inBase64, int inBinlength )
{
	int i, j;
	unsigned char lCurrent;
 
	for ( i = 0, j = 0 ; i < inBinlength ; i += 3 )
	{
        	lCurrent = (inBindata[i] >> 2) ;
        	lCurrent &= (unsigned char)0x3F;
        	inBase64[j++] = inBase64char[(int)lCurrent];
 
        	lCurrent = ( (unsigned char)(inBindata[i] << 4 ) ) & ( (unsigned char)0x30 ) ;
        	if ( i + 1 >= inBinlength )
        	{
            		inBase64[j++] = inBase64char[(int)lCurrent];
            		inBase64[j++] = '=';
            		inBase64[j++] = '=';
            		break;
        	}
        	lCurrent |= ( (unsigned char)(inBindata[i+1] >> 4) ) & ( (unsigned char) 0x0F );
        	inBase64[j++] = inBase64char[(int)lCurrent];
 
        	lCurrent = ( (unsigned char)(inBindata[i+1] << 2) ) & ( (unsigned char)0x3C ) ;
		if ( i + 2 >= inBinlength )
		{
		    inBase64[j++] = inBase64char[(int)lCurrent];
		    inBase64[j++] = '=';
		    break;
		}
		lCurrent |= ( (unsigned char)(inBindata[i+2] >> 6) ) & ( (unsigned char) 0x03 );
		inBase64[j++] = inBase64char[(int)lCurrent];
	 
		lCurrent = ( (unsigned char)inBindata[i+2] ) & ( (unsigned char)0x3F ) ;
		inBase64[j++] = inBase64char[(int)lCurrent];
	}
	
	inBase64[j] = '\0';
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

工匠Sola

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值