本项目采用C/C++编程语言实现AES(Advanced Encryption Standard)加密标准,涵盖数据的加密与解密过程。通过严谨的算法设计及高效的代码编写,确保信息安全传输的同时提高处理效率。
分组长度为128比特,即16字节。定义位操作LOAD32H(x, y) 将uint8_t 类型的y[4] 转换成 uint32_t 类型的x;STORE32H(x, y) 则将uint32_t类型的x转换为uint8_t类型数组y[4]。此外,BYTE(x, n) 用于从一个uint32_t类型的变量x中提取第n个字节(从低位开始计数)。在密钥扩展过程中使用了MIX(x),该操作包括子词替换和循环左移一位的步骤;ROF32(x, n) 和 ROR32(x, n) 分别代表uint32_t类型的x向左或向右循环移动n位的操作。
对于密钥扩展,系统接收一个16字节(即128比特)作为初始密钥,这相当于4个连续的32位字。因此Nb=4,并且Nr等于10(即进行10轮操作)。整个过程将生成总共4*(10+1)= 44个这样的32位字,其中最初的四个字直接使用原始密钥值。