对称加密算法之高级数据加密标准-AES

2024-06-19 11:08

本文主要是介绍对称加密算法之高级数据加密标准-AES,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对称加密算法之AES算法

  • 1. AES算法简介
  • 2. 模型分析
  • 3. 代码实现
    • 3.1 算法实现
    • 3.2 测试代码
    • 3.3 执行结果

该系列文章列表

1.网络及数据安全概念及领域概述
网络安全之数据加密/解密/签名/验签/数字证书
2.对称加密/解密算法
对称加密算法之高级数据加密标准-AES
对称加密之三重DES—DESede
对称加密算法之DES

3.非对称加密/解密算法
非对称加密算法概述
非对称加密之密钥交换算法-DH
非对称加密之RSA算法
非对称加密之Curve25519加密算法
4.其他加密解密算法
异或加密算法
5. 消息摘要算法
SHA安全散列算法
6. 数字证书
7. 网络安全协议

1. AES算法简介

DES算法的漏洞的发现加速了对称加密算法的改进,AES算法基于此诞生。

AES相关的算法实现有MARS、RC6、Rigndael、 Serpent和Twofish。

Rigndael算法以其密钥设置快、存储要求低,在硬件实现和限制存储条件下性能优异当选AES算法。
经过验证,目前的AES算法能够有效抵御已知的针对DES算法的所有攻击方法,如部分差分攻击、相关密钥攻击等。

AES算法因密钥建立时间短、灵敏性好、内存需求低等优点,在各领域有广泛研究和应用。

目前,AES在移动通信系统(Universal Mobile Telecommunications System, 简称UMTS)、SSH协议等软件中都有使用。此外,在一些无线路由器中也使用AES算法构建加密协议。

2. 模型分析

AES算法模型同对称算法模型一致
在这里插入图片描述

3. 代码实现

Java及Bouncy Castle对AES算法的实现细节如下所示:

AES算法

算法密钥长度密钥默认值工作模式填充方式备注
AES128、192、256128ECB、CBC、PCBC、CTR、CTS、CFB、CFB8至CFB128、OFB、OFB8至OFB128NoPadding、PKCS5Padding、ISO10126PaddingAndorid
AES同上同上同上PKCS7Padding、ZeroBytePaddingBouncy Castle实现

3.1 算法实现

package com.calvin.android.secrity;import java.security.Key;import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;/*** Author:cl* Email:lhzheng@grandstream.cn* Date:20-10-19*/
public class AesCoder {/*** 密钥算法*/public static final String KEY_ALGORITHM = "AES";/*** 加密/解密算法/工作模式/填充方式* Java6 支持PKCS5PADDING填充方式* Bouncy Castle支持PKCS7Padding填充方式*/public static final String CIPHER_ALGORITHM = "AES/ECB/PKCS5Padding";private static Key toKey(byte[] key) throws Exception {SecretKey secretKey = new SecretKeySpec(key, KEY_ALGORITHM);return secretKey;}public static byte[] decrypt(byte[] data, byte[] key) throws Exception {//还原密钥Key k = toKey(key);//实例化,使用PKCS7Padding填充方式,按如下方式实现// Cipher.getInstance(CIPHER_ALGORITHM, "BC");Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);//初始化,设置为解密模式cipher.init(Cipher.DECRYPT_MODE, k);//执行数据解密return cipher.doFinal(data);}public static byte[] encrypt(byte[] data, byte[] key) throws Exception {//还原密钥Key k = toKey(key);//实例化,使用PKCS7Padding填充方式,按如下方式实现// Cipher.getInstance(CIPHER_ALGORITHM, "BC");Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);//初始化,设置为解密模式cipher.init(Cipher.ENCRYPT_MODE, k);//执行数据解密return cipher.doFinal(data);}public static byte[] initKey() throws Exception {//实例化KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);//AES要求密钥长度为128位、192位或256位kg.init(256);//生成秘密密钥SecretKey secretKey = kg.generateKey();//获取密钥的二进制编码形式return secretKey.getEncoded();}
}

3.2 测试代码

@Testpublic void AESTest() throws Exception {String inputStr = "AES加密/解密算法";byte[] inputData = inputStr.getBytes();System.out.println("原文:\n"+inputStr);//初始化密钥byte[] key = AesCoder.initKey();System.out.println("密钥:\n"+Base64.encodeToString(key, Base64.DEFAULT));//加密inputData = AesCoder.encrypt(inputData, key);System.out.println("加密后:\n"+Base64.encodeToString(inputData, Base64.DEFAULT));//解密byte[] outputData = AesCoder.decrypt(inputData, key);String outputStr = new String(outputData);System.out.println("解密后:\n"+outputStr);//校验assertEquals(inputStr, outputStr);}

3.3 执行结果

2020-10-19 18:06:11.732 31820-31838/com.calvin.android.sample I/System.out: 原文:
2020-10-19 18:06:11.732 31820-31838/com.calvin.android.sample I/System.out: AES加密/解密算法
2020-10-19 18:06:11.733 31820-31838/com.calvin.android.sample I/System.out: 密钥:
2020-10-19 18:06:11.733 31820-31838/com.calvin.android.sample I/System.out: Qd4u+0nc9Nx6GU3zm0E75x+HTAfeoSmuRrKkc6H4Krg=
2020-10-19 18:06:11.739 31820-31838/com.calvin.android.sample I/System.out: 加密后:
2020-10-19 18:06:11.739 31820-31838/com.calvin.android.sample I/System.out: LiSIkHoTgotvJ2qc96aKlcQ1ub/zVfkUnlQqDTsnp9g=
2020-10-19 18:06:11.740 31820-31838/com.calvin.android.sample I/System.out: 解密后:
2020-10-19 18:06:11.740 31820-31838/com.calvin.android.sample I/System.out: AES加密/解密算法

这篇关于对称加密算法之高级数据加密标准-AES的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074851

相关文章

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

SQL Server中,查询数据库中有多少个表,以及数据库其余类型数据统计查询

sqlserver查询数据库中有多少个表 sql server 数表:select count(1) from sysobjects where xtype='U'数视图:select count(1) from sysobjects where xtype='V'数存储过程select count(1) from sysobjects where xtype='P' SE

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述。以下是从不同角度对气象站的种类和应用范围的介绍: 一、气象站的种类 根据用途和安装环境分类: 农业气象站:专为农业生产服务,监测土壤温度、湿度等参数,为农业生产提供科学依据。交通气象站:用于公路、铁路、机场等交通场所的气象监测,提供实时气象数据以支持交通运营和调度。林业气象站:监测林区风速、湿度、温度等气象要素,为林区保护和

数据时代的数字企业

1.写在前面 讨论数据治理在数字企业中的影响和必要性,并介绍数据治理的核心内容和实践方法。作者强调了数据质量、数据安全、数据隐私和数据合规等方面是数据治理的核心内容,并介绍了具体的实践措施和案例分析。企业需要重视这些方面以实现数字化转型和业务增长。 数字化转型行业小伙伴可以加入我的星球,初衷成为各位数字化转型参考库,星球内容每周更新 个人工作经验资料全部放在这里,包含数据治理、数据要

如何在Java中处理JSON数据?

如何在Java中处理JSON数据? 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨在Java中如何处理JSON数据。JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,在现代应用程序中被广泛使用。Java通过多种库和API提供了处理JSON的能力,我们将深入了解其用法和最佳

两个基因相关性CPTAC蛋白组数据

目录 蛋白数据下载 ①蛋白数据下载 1,TCGA-选择泛癌数据  2,TCGA-TCPA 3,CPTAC(非TCGA) ②蛋白相关性分析 1,数据整理 2,蛋白相关性分析 PCAS在线分析 蛋白数据下载 CPTAC蛋白组学数据库介绍及数据下载分析 – 王进的个人网站 (jingege.wang) ①蛋白数据下载 可以下载泛癌蛋白数据:UCSC Xena (xena

YTK的高级使用

YTKUrlFilterProtocol 接口 YTKUrlFilterProtocol 接口用于实现对网络请求URL或参数的重写,例如可以统一为网络请求加上一些参数,或者修改一些路径。 例如:在猿题库中,我们需要为每个网络请求加上客户端的版本号作为参数。所以我们实现了如下一个YTKUrlArgumentsFilter 类,实现了 YTKUrlFilterProtocol 接口: //

Java实现MD5加密总结

Java实现MD5加密总结 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 1. 什么是MD5加密 MD5是一种常用的哈希算法,用于将任意长度的数据通过哈希运算转换为固定长度的数据串,通常为128位的二进制串,常用于对密码等敏感信息进行加密存储或传输。 2. Java实现MD5加密的方法 2.1 使用java.sec

中国341城市生态系统服务价值数据集(2000-2020年)

生态系统服务反映了人类直接或者间接从自然生态系统中获得的各种惠益,对支撑和维持人类生存和福祉起着重要基础作用。目前针对全国城市尺度的生态系统服务价值的长期评估还相对较少。我们在Xie等(2017)的静态生态系统服务当量因子表基础上,选取净初级生产力,降水量,生物迁移阻力,土壤侵蚀度和道路密度五个变量,对生态系统供给服务、调节服务、支持服务和文化服务共4大类和11小类的当量因子进行了时空调整,计算了