浮点数组的异或加密



我想加密浮点型数组并使用相同的函数再次解码它。我在网上读了几个帖子,但我找不到一个让我快乐的解决方案。我试图将浮点型指针转换为char*并使用我的char类型键对结果进行异或。这里是我的encode函数:

const char* key = "mykey";
int keylen = sizeof(key) / sizeof(key[0]);
void encodeData(float *data, int size)
{
    int bytes = (int)(sizeof(float)/sizeof(char));
    for(int i=0; i<size; i++)
    {
        for(int j=0; j<bytes; j++)
        {
            data[i] = *(((char *)&data[i]) + j) ^ (key[(bytes*i)%keylen]);
        }
    }
}

编译工作,但我没有得到相同的结果后,en和解码。我做错了什么?

修正:

void encodeData(float *data, int size) 
{ 
     int bytes = (int)(sizeof(float)/sizeof(char)); 
     char *tmp = (char *) data; 
     for(int i=0; i<bytes*size; i++) 
     { 
         *(tmp+i) = *(tmp+i) ^ key[i%keylen]; 
     } 
     data = (float*) tmp; 
 }

最新更新