AES加密算法之轮密钥加操作

以AES算法明文128bit、密钥128bit为例:

轮密钥加操作就是将轮密钥与明文(状态)按比特异或。轮密钥通过密钥扩展得到,初始密钥与初始明文均是用户自己设置。简单来说,密钥加操作就是逐字节相加,有限域GF(28)上的加法是2加法,即异或。


附上自己敲的C语言源码:

#include 
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;
}
程序运行结果如下:


AES加密算法之轮密钥加操作_第1张图片

你可能感兴趣的:(分组密码,AES,密钥加)