c语言 encode,Base64 Encode C语言实现

主要方法是base64_encode,它需要两个参数,需要加密的字符串和它的长度(虽然长度也可以在该方法内得到,这一点参考了刚才那个链接的方法。)我都是用的int类型,默认它是4字节32bit的,如果不妥,大家不要责怪。解密以后再做吧。

#include

const char base[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";

char* base64_encode(char* data, int data_len);

int main(int argc, char* argv[])

{

char *t = "你好ma哈哈哈哈哈捏黑的饿登记费ug啊接ia阿尔i阿尔就ijeiie进而饿接ie";

int i = 0;

int j = strlen(t);

/*

for (i=0 ;i

{

printf("%2X %c/n", *t & 0xFF, *t);

t++;

}

*/

printf("/n%s/n", base64_encode(t, j));

return 0;

}

char *base64_encode(char* data, int data_len)

{

//int data_len = strlen(data);

int prepare;

int ret_len;

int temp = 0;

char *ret = NULL;

char *f = NULL;

int tmp = 0;

char changed[4];

int i = 0;

ret_len = data_len / 3;

temp = data_len % 3;

if (temp > 0)

{

ret_len += 1;

}

ret = (char *)malloc(ret_len*4 + 1);

if ( ret == NULL)

{

printf("No enough memory./n");

exit(0);

}

f = ret;

while (tmp < data_len)

{

temp = 0;

prepare = 0;

memset(changed, '/0', 4);

while (temp < 3)

{

//printf("tmp = %d/n", tmp);

if (tmp >= data_len)

{

break;

}

prepare = ((prepare << 8) | (data[tmp] & 0xFF));

tmp++;

temp++;

}

prepare = (prepare<

//printf("before for : temp = %d, prepare = %d/n", temp, prepare);

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

{

if (temp < i)

{

changed[i] = 0x40;

}

else

{

changed[i] = (prepare>>((3-i)*6)) & 0x3F;

}

*f = base[changed[i]];

//printf("%.2X", changed[i]);

f++;

}

}

*f = '/0';

return ret;

}

关于“你好ma哈哈哈哈哈捏黑的饿登记费ug啊接ia阿尔i阿尔就ijeiie进而饿接ie”这一串文字,加密结果是:

xOO6w21huf65/rn+uf65/sTzutq1xLb2tce8x7fRdWewob3TaWGworb7abCitvu+zWlqZWlpZb34tvi29r3TaWU=

但是我使用JXTA2.5所带的org.bouncycastle.util.encoders.UrlBase64加密结果稍有出入:

xOO6w21huf65_rn-uf65_sTzutq1xLb2tce8x7fRdWewob3TaWGworb7abCitvu-zWlqZWlpZb34tvi29r3TaWU.

差别在于加减不同,“=”变“.”,“/”变“_”。说起JXTA,我有气,JXTA技术手册都有JXTA的安全方面的类,2.5中没有找到了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Linux C语言实现Base64加密的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> static const char base64_chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; char *base64_encode(const unsigned char *data, size_t input_length, size_t *output_length) { *output_length = 4 * ((input_length + 2) / 3); char *encoded_data = malloc(*output_length + 1); if (encoded_data == NULL) return NULL; for (size_t i = 0, j = 0; i < input_length;) { uint32_t octet_a = i < input_length ? (unsigned char)data[i++] : 0; uint32_t octet_b = i < input_length ? (unsigned char)data[i++] : 0; uint32_t octet_c = i < input_length ? (unsigned char)data[i++] : 0; uint32_t triple = (octet_a << 0x10) + (octet_b << 0x08) + octet_c; encoded_data[j++] = base64_chars[(triple >> 3 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 2 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 1 * 6) & 0x3F]; encoded_data[j++] = base64_chars[(triple >> 0 * 6) & 0x3F]; } for (size_t i = 0; i < (*output_length % 4); i++) { encoded_data[*output_length - 1 - i] = '='; } return encoded_data; } int main(int argc, char *argv[]) { const char *input_str = "hello, world!"; size_t input_len = strlen(input_str); size_t output_len = 0; char *encoded_str = base64_encode((const unsigned char *)input_str, input_len, &output_len); printf("Encoded string: %s\n", encoded_str); free(encoded_str); return 0; } ``` 这个示例代码使用了一个包含64个字符的字符表(base64_chars),以及一个base64_encode函数,该函数将输入的数据编码成Base64格式,并返回编码后的字符串。在main函数中,我们首先声明一个字符串,然后计算它的长度,并将其传递给base64_encode函数。该函数将返回一个指向编码后的字符串的指针,我们可以将其打印出来。最后,我们释放了分配给编码字符串的内存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值