几周前,我收到了一些代码,作为我感兴趣的加密工作申请的一部分。他们给我发了一个代码,基本上想看看我是否理解它并可以改进它。
我尽了最大努力,但所有代码对我来说都是全新的,我不知道它做了什么。我最终放弃了它,因为我还有其他事情要做。但是,我仍然对学习它非常感兴趣,只是为了知识。谁能帮我更多地了解这种类型的编程或具体做什么?
我会尽量减少它并给出我的印象。
这是进行实际加密的部分;据我所知,使用 XOR 加密。它是否正确?我也相信 input_2 和 input_1 被错误地切换了。
typedef int int32;
typedef char int8;
void change_it(int8 *output, int8 *input_1, const int8 *input_2, int32 length)
{
int32 i = 0;
for(i=0; i<length; i++)
{
output[i] = (int8)(input_1[i] ^ input_2[i]);
}
return;
}
在这里,他们重载了 anitoa
以将字符串转换为十进制或十六进制数字,尽管我不确定出于什么目的。
void itoa( int32 num, int8 *alpha, int32 radix )
{
if( radix == 10 )
{
sprintf(alpha, "%i", num);
}
else if( radix == 16 )
{
sprintf(alpha, "%X", num);
}
}
这是 main 调用的主要运行函数。它做了一些奇怪的按位操作,然后调用了 change_it 4 次。这是最让我难过的部分。
int8 *modify_it(int32 modifier, const int8 *input_1, int32 length)
{
int8 leading[3];
int32 i_leading;
int8 * temp_string = NULL;
int8 * ret;
int32 i = 0;
itoa(modifier/2, leading, 10);
i_leading = atoi(leading);
temp_string = (int8 *) malloc(8);
ret = (int8 *) malloc(length);
memset(temp_string, 0, 8);
temp_string[0] = 0;
if( (modifier+1)%2 == 0 ) {
temp_string[0] = (int8)((i_leading<<4) + 8);
}
else {
temp_string[0] = (int8)(i_leading<<4);
}
for(i=0; i<(length>>3); i++)
{
change_it(ret+i*8, temp_string, input_1+i*8, 8);
}
free(temp_string);
return ret;
}
最后但并非最不重要的一点是启动它的主要功能。
int main(int argc, char **argv) {
int8 data[32];
memset(data, 0x0A, sizeof(data));
int8 *resp = modify_it(0xFF, data, sizeof(data));
free(resp);
system("PAUSE");
return 0;
}