-3

我编写加密\解密系统(原型)。该系统有 188 字节的数据包。并加扰:

加密(Python):

#key = 40
packet[4]+packet[40:]+packet[4:40]

解密(C):

//in_buffer - main char* massive
//offs - offset of packet (length 188)
//key - int for separator (40 in example before)

void encryption(byte* in_buffer, int offs, int key)
{
  byte temp[188];
  int i;
  //write packet[4:40] to temp
  for(i = 4;i < key; i++)
  {  
    temp[i] = in_buffer[offs+i];
  }
  //write packet[40:] to top
  for(i = 4;i < 188 - key+4; i++)
  {  
    in_buffer[offs+i] = in_buffer[offs+i+key-4];
  }
  //write packet[4:40] of temp to in_buffer[152:]
  for(i = 4;i < key; i++)
  {  
    in_buffer[offs+i+188-key] = temp[i];
  }
}

它适用于 key = 96,但不适用于任何其他键!为什么?

4

1 回答 1

0

所有这些数组下标算术都是令人讨厌且容易出错的。用于memcpy将各个部分“附加”到位:

byte temp[188];
int pos = 0;

memcpy(temp + pos, in_buffer, 4); // append in_buffer[:4]
pos += 4;
memcpy(temp + pos, in_buffer + 188 - key + 4, key - 4); // append in_buffer[188-key+4:188]
pos += key-4;
memcpy(temp + pos, in_buffer + 4, 188 - key); // append in_buffer[4:188-key+4]
于 2012-09-21T11:03:11.860 回答