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

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值