带有std::vector的XTEA函数



我正在尝试用XTEA加密std::向量。因为使用std::vector在处理大量数据时会带来各种好处,所以我想使用它

XTEA算法使用两个无符号长(v0和v1)对它们进行加密,这两个长取64位数据。

xtea_enc(unsigned char buf[], int length, unsigned char key[], unsigned char** outbuf)
/* Source http://pastebin.com/uEvZqmUj */
unsigned long v0 = *((unsigned long*)(buf+n));  
unsigned long v1 = *((unsigned long*)(buf+n+4));

我的问题是,我正在寻找将我的字符向量转换为无符号长指针的最佳方法。

或者,对于加密函数,是否有另一种将矢量拆分为64位部分的方法?

认识到每个字符都是一个字节;因此一个64位数字由8个字节或两个32位数字组成。

因此,一个32位数字可以存储4个字节,因此对于char向量中的每个8字节块,将一对4字节数字存储在一对32位数字中。然后将这对传递给xtea函数,类似于:

uint32_t datablock[2];
datablock[0] = (buf[0] << 24) | (buf[1] << 16)  | (buf[2] << 8) | (buf[3]);
datablock[1] = (buf[4] << 24) | (buf[5] << 16)  | (buf[6] << 8) | (buf[7]);

其中,在本例中,buf是类型char[8](或更合适的uint8_t[8])。

比特移位'<lt;'运算符移动给定字节的位应该存储在uint32_t中的位置(因此,例如,上面示例中的第一个字节存储在数据块[0]的前8位中)。"|"运算符提供了所有位的连接,这样您就可以得到完整的32位数字。希望这是有道理的。

我的问题是,我正在寻找将我的字符向量转换为无符号长指针的最佳方法。

从C++11开始的((unsigned long*)vec.data())还是在C++11之前的((unsigned long*)&vec[0]))

附言:我想迟早会有人来争论它应该是reinterpret_cast<unsigned long*>()之类的,他们可能是对的。

此外,我使用了std::字符串,但以下是我如何执行enciper循环:

        string message = readMessage();
        for (size_t i = 0; i < message.length(); i += 8)
        {
            encipher(32, (uint32_t *)&message[i], keys);
        }
        // now message is encrypted

        for (size_t i = 0; i < message.length(); i += 8)
        {
            decipher(32, (uint32_t *)&message[i], keys);
        }
        // now message is decrypted (still may have padding bytes tho)
  • 我刚刚使用了XTEA的维基百科页面中的示例C enciper/deciper函数

最新更新