AES算法测试用例程序Java实现(密钥长度128比特)

本文详细介绍了AES算法的Java实现,包括密钥长度为128比特的加密和解密过程。内容涵盖AES算法的四个核心步骤:字节代替、行移位、列混合和轮密钥加,以及秘钥扩展的详细解释。通过程序测试用例,展示了如何手动输入和随机生成明文、密文及秘钥进行加密解密操作。
摘要由CSDN通过智能技术生成

AES算法测试用例程序Java实现(密钥长度128比特)   

                         ——2018.10.22

目录

1引言... 1

    1.1任务概要... 1

    1.2运行环境和开发环境... 1

    1.3密码算法原理简单介绍... 1

2  程序各模块详细设计... 3

    2.1核心模块主要实现算法的流程... 3

    2.2 AES加密的算法说明和实现方式... 4

        2.2.1字节代替(Subbyte)... 4

        2.2.2行移位(ShiftRows)... 4

        2.2.3列混合(MixColumns)... 5

        2.2.4 轮秘钥加(AddRoundKey)... 7

        2.2.5 秘钥扩展(KeyExpansion)... 7

    2.3 AES解密的算法说明和实现方式... 8

        2.3.1逆行移位(InvShiftRows)... 8

        2.3.2逆字节代替(InvSubbyte)... 9

        2.3.3逆列混合(InvMixColumns)... 10

3  程序测试... 10

      3.1手动输入明文和秘钥测试过程... 10

      3.2随机生成明文和秘钥测试过程... 11

      3.3手动输入密文和秘钥测试过程... 12

4  密码算法课程设计实践总结... 13

5  参考文献... 14

 

 

1引言

1.1任务概要

  1. 实现AES加密和解密基本功能;
  2. 实现AES加密测试用例功能,具体如下:
  • 随机产生n组128比特明文,加密产生n组128比特密文,密钥不变;b)操作简单,界面美观。
  • 输入和输出要求:
  1. 用函数实现AES加密和解密
  2. 输入和输出的128比特明文和密文采用十六进制
  3. 要求至少有一组来自标准fips-197的测试。
  4. 随机产生的明文和加密后的明文(即密文)保存为txt文件,保存格式为每行记录一组明文和对应密文。如txt文件格式

明文:0xbce3 ……     密文:0x……

明文:0x……     密文:0x……

加密密钥为:0x……

  •  解密验证,从(4)中txt文件,获取任意一组密文和密钥,解密输出明文,并输出显示在屏幕上。

1.2运行环境和开发环境

  1. 运行环境:JVM;
  2. 开发环境:Windows10&#x
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值