linux系统base64加密算法,C有没有好用Linux下的的Base64加密的方法?中文转换有问题...

C有没有好用Linux下的的Base64加密的方法?中文加密有问题,编码以后的字符串不能解码,但是数字和英文加密后的字符串没问题,可以解码。

这是我在网上找的方法

char * Encbase64(char * orgdata,unsigned long orglen,unsigned long newlen)

{

charp=NULL,ret=NULL;

int tlen=0;

if (orgdata==NULL|| orglen==0)

return NULL ;

tlen=orglen/3;

if(tlen%3!=0) tlen++;

tlen=tlen4;

newlen=tlen;

if ((ret=(char)malloc(tlen+1))==NULL)

return NULL;

memset(ret,0,tlen+1);

p=orgdata;tlen=orglen;

int i=0,j=0;

while(tlen>0)

{

Udata.c[0]=Udata.c[1]=Udata.c[2]=0;

for (i=0;i<3;i++)

{

if (tlen<1) break;

Udata.c[i]=(char)p;

tlen--;

p++;

}

if (i==0) break;

switch (i)

{

case 1:

/ret[j++]=_Base[Udata.Sdata.d];

ret[j++]=_Base[Udata.Sdata.c];

ret[j++]=_Base[64];

ret[j++]=_Base[64];*/

ret[j++]=_Base[Udata.c[0]>>2];

ret[j++]=_Base[((Udata.c[0]&0x03)<<4)|((Udata.c[1]&0xf0)>>4)];

ret[j++]=_Base[64];

ret[j++]=_Base[64];

break;

case 2:

/*ret[j++]=_Base[Udata.Sdata.d];

ret[j++]=_Base[Udata.Sdata.c];

ret[j++]=_Base[Udata.Sdata.b];

ret[j++]=_Base[64];*/

ret[j++]=_Base[Udata.c[0]>>2];

ret[j++]=_Base[((Udata.c[0]&0x03)<<4)|((Udata.c[1]&0xf0)>>4)];

ret[j++]=_Base[((Udata.c[1]&0x0f)<<2)|((Udata.c[2]&0xc0)>>6)];

ret[j++]=_Base[64];

break;

case 3:

/*ret[j++]=_Base[Udata.Sdata.d];

ret[j++]=_Base[Udata.Sdata.c];

ret[j++]=_Base[Udata.Sdata.b];

ret[j++]=_Base[Udata.Sdata.a];*/

ret[j++]=_Base[Udata.c[0]>>2];

ret[j++]=_Base[((Udata.c[0]&0x03)<<4)|((Udata.c[1]&0xf0)>>4)];

ret[j++]=_Base[((Udata.c[1]&0x0f)<<2)|((Udata.c[2]&0xc0)>>6)];

ret[j++]=_Base[Udata.c[2]&0x3f];

break;

default:

break;

}

}

ret[j]='\0';

return ret;

}

Linux下aa就是调用的上面的方法,编码以后的字符是错的,完全不能解码。

725033546057afefd9fbd7fce8cc6f6a.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值