以AES算法明文128bit、密钥128bit为例:
轮密钥加操作就是将轮密钥与明文(状态)按比特异或。轮密钥通过密钥扩展得到,初始密钥与初始明文均是用户自己设置。简单来说,密钥加操作就是逐字节相加,有限域GF(28)上的加法是模2加法,即异或。
附上自己敲的C语言源码:
#include <iostream>
using namespace std;
void PrintfMatrix(unsigned char m[4][4])
{
for(int i=0;i<4;i++)
{
for(int j=0;j<4;j++)
{
printf("%2x",m[i][j]);
if(j%4==3)
puts("");
}
}
}
void AddRoundKey(unsigned char state[4][4],unsigned char key[4][4]) //密钥加函数
{
int i,j;
for (i=0;i<4;i++)
{
for(j=0;j<4;j++)
{
state[i][j]^=key[i][j]; //明文与密钥的异或,即密钥加
}
}
}
int main()
{
unsigned char state[4][4]={
0,4,8,12,
1,5,9,13,
2,6,10,14,
3,7,11,15,
};
unsigned char key[4][4]={
0,1,2,3,
4,5,6,7,
8,9,10,11,
12,13,14,15,
};
printf("明文为:\n");PrintfMatrix(state);
printf("密钥为:\n");PrintfMatrix(key);
AddRoundKey(state,key); //在主函数中调用密钥加函数
printf("密钥加结果:\n");PrintfMatrix(state);
return 0;
}
程序运行结果如下: