gpt4 book ai didi

c++ - 在 C++ 中实现 AES-128 混合列函数

转载 作者:太空宇宙 更新时间:2023-11-04 12:35:49 25 4
gpt4 key购买 nike

我正在尝试在 C++ 中实现“混合列”函数及其反函数。

我有一份作业来实现 AES-128。我让所有其他功能(以及反函数)正常工作。但是,我正在努力让 mixcolumn 函数正常工作。我在应用函数之前打印明文,然后我应用混合列及其逆列并打印出结果。两个输出不匹配,我不知道为什么会这样。

void mixColumns(array< array<uint8_t, 4>, 4> &state)
{
//Create temp variable to store intermediate results
array< array<uint8_t,4>, 4> temp;
//Perform matrix multiplication under GF
for(int i=0;i<4;i++)
{
temp[0][i] = (0x02 * state[0][i]) ^ (0x03 * state[1][i]) ^ state[2][i] ^ state[3][i];
temp[1][i] = state[0][i] ^ (0x02 * state[1][i]) ^ (0x03 * state[2][i]) ^ state[3][i];
temp[2][i] = state[0][i] ^ state[1][i] ^ (0x02 * state[2][i]) ^ (0x03 * state[3][i]);
temp[3][i] = (0x03 * state[0][i]) ^ state[1][i] ^ state[2][i] ^ (0x02 * state[3][i]);
}
//Fill state with mix column data
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
state[j][i] = temp[j][i];
}

void invMixColumns(array< array<uint8_t, 4>, 4> &state)
{
//Create temp variable to store intermediate results
array< array<uint8_t,4>, 4> temp;
for(int i=0;i<4;i++)
{
temp[0][i] = (0x0E * state[0][i]) ^ (0x0B * state[1][i]) ^ (0x0D * state[2][i]) ^ (0x09 * state[3][i]);
temp[1][i] = (0x09 * state[0][i]) ^ (0x0E * state[1][i]) ^ (0x0B * state[2][i]) ^ (0x0D * state[3][i]);
temp[2][i] = (0x0D * state[0][i]) ^ (0x09 * state[1][i]) ^ (0x0E * state[2][i]) ^ (0x0B * state[3][i]);
temp[3][i] = (0x0B * state[0][i]) ^ (0x0D * state[1][i]) ^ (0x09 * state[2][i]) ^ (0x0E * state[3][i]);
}
//Fill state with inverse column data
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
state[j][i] = temp[j][i];

}

输入(和预期输出):1101101011101101100010110111011001100110000110110101100010110100100110010001010101010100111001011100111110011010101010

使用 mixCoulmns 和 invMixColumns 输出:10111010111010010011111110010010011101101010111110001100001000000100100101101001001011001101010111111011000110110011010100p>

最佳答案

设法修复它,但忘记更新我的帖子。正如@doug 指出的那样,我没有在 GF(2^8) 下使用乘法,所以我得到了无效的答案。只需对这些字段的查找表进行硬编码即可解决此问题(尽管我不确定这是否是最有效的方法)。

关于c++ - 在 C++ 中实现 AES-128 混合列函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56412046/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com