package com.dc; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.Security; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.KeyGenerator; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKey; /* ****************** 类说明 ********************* * class : DcAESUtil * @author : ncc * create time : 2017-12-19 上午10:13:17 * @version : 1.0 * description : AES密码学中的高级加密标准(Advanced Encryption Standard,AES),又称 高级加密标准 * Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES, * 已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与 * 技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。 * 2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。 * 该算法为比利时密码学家Joan Daemen和Vincent Rijmen所设计,结合两位作者的名字, * 以Rijndael之命名之,投稿高级加密标准的甄选流程。(Rijdael的发音近于 "Rhinedoll"。) * @see : * ************************************************/ public class DcAESUtil { // KeyGenerator 提供对称密钥生成器的功能,支持各种算法 private KeyGenerator keygen; // SecretKey 负责保存对称密钥 private SecretKey deskey; // Cipher负责完成加密或解密工作 private Cipher c; // 该字节数组负责保存加密的结果 private byte[] cipherByte; public DcAESUtil() throws NoSuchAlgorithmException, NoSuchPaddingException { Security.addProvider(new com.sun.crypto.provider.SunJCE()); // 实例化支持DES算法的密钥生成器(算法名称命名需按规定,否则抛出异常) keygen = KeyGenerator.getInstance("AES"); // 生成密钥 deskey = keygen.generateKey(); // 生成Cipher对象,指定其支持的DES算法 c = Cipher.getInstance("AES"); } /* ******************************************** * method name : Encrytor * description : 对字符串加密 * @return : byte[] * @param : @param str * @param : @return * @param : @throws InvalidKeyException * @param : @throws IllegalBlockSizeException * @param : @throws BadPaddingException * modified : ncc , 2017-12-19 * @see : * ********************************************/ public byte[] Encrytor(String str) throws InvalidKeyException, IllegalBlockSizeException, BadPaddingException { // 根据密钥,对Cipher对象进行初始化,ENCRYPT_MODE表示加密模式 c.init(Cipher.ENCRYPT_MODE, deskey); byte[] src = str.getBytes(); // 加密,结果保存进cipherByte cipherByte = c.doFinal(src); return cipherByte; } /* ******************************************** * method name : Decryptor * description : 对字符串解密 * @return : byte[] * @param : @param buff * @param : @return * @param : @throws InvalidKeyException * @param : @throws IllegalBlockSizeException * @param : @throws BadPaddingException * modified : ncc , 2017-12-19 * @see : * ********************************************/ public byte[] Decryptor(byte[] buff) throws InvalidKeyException, IllegalBlockSizeException, BadPaddingException { // 根据密钥,对Cipher对象进行初始化,DECRYPT_MODE表示加密模式 c.init(Cipher.DECRYPT_MODE, deskey); cipherByte = c.doFinal(buff); return cipherByte; } /** * @param args * @throws NoSuchPaddingException * @throws NoSuchAlgorithmException * @throws BadPaddingException * @throws IllegalBlockSizeException * @throws InvalidKeyException */ public static void main(String[] args) throws Exception { DcAESUtil de = new DcAESUtil(); String msg = "欢迎光临得草之家!"; byte[] encontent = de.Encrytor(msg); byte[] decontent = de.Decryptor(encontent); System.out.println("明文是:" + msg); System.out.println("加密后:" + new String(encontent)); System.out.println("解密后:" + new String(decontent)); } }
相关推荐
这个程序应当包含了上述知识点的具体应用,你可以通过阅读源代码、编译和运行来进一步理解和学习AES加密解密的实现细节。这个实战例程可以帮助开发者更好地掌握Qt环境下的加密解密操作,提高数据安全保护能力。
《AES加密解密实验报告》 AES,全称为高级加密标准(Advanced Encryption Standard),是密码学领域中的一个重要标准,由美国联邦政府采纳,用于替换原有的DES加密算法。AES由比利时密码学家Joan Daemen和Vincent ...
在本项目中,"用C语言实现的AES加密解密算法"是针对AES算法的一种C语言实现,这允许开发者在不依赖特定库的情况下,在C环境中进行数据的加密和解密操作。 首先,我们需要理解AES的工作原理。AES的核心是基于替换和...
在iOS和Android平台上实现AES加密解密是开发者经常遇到的任务,尤其对于需要跨平台传输和存储敏感信息的场景。本篇文章将详细探讨AES加密解密算法在iOS和Android平台上的实现原理以及具体步骤。 首先,AES算法基于...
"本地图片AES加密解密"是一个针对这个问题提出的技术方案,旨在保护存储在本地设备上的图片不被未经授权的第三方访问。AES(Advanced Encryption Standard)加密是一种广泛应用的对称加密算法,因其高效和安全性而...
在uni-app中,可以使用JavaScript的crypto-js库来实现AES加密解密。首先,你需要通过HBuilderX引入该库,然后在uni-app代码中使用: ```javascript const CryptoJS = require('crypto-js'); const key = 'your_...
本压缩包"uniapp 前后端AES加密解密.rar"正是为了解决这一问题,它包含了在uniapp环境下实现前后端AES加密解密的方法。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,具有...
' 功能: AES加密解密 password<==>hwWpiegaWDeE8kTlb/5BQg== , 8705a989e81a583784f244e56ffe4142 ' [Str] 预备转换的byte ' [StrKey] 16位的密钥 ' [StrIv] 16位的偏移 ' [Encrypt] 加密(缺省值)还是解密 ' ...
标题 "C语言实现的AES加密解密" 涉及到的是高级加密标准(Advanced Encryption Standard,简称AES),这是一种广泛使用的对称加密算法,用于保护数据的安全性。AES由NIST(美国国家标准与技术研究所)在2001年标准化...
VB.NET实现AES加密解密代码,可直接使用
本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原先的输入,运行的结果...
"C/C++与Java互通AES加密解密"的主题就是这两个议题的结合。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,提供了强效的数据保护。本话题主要探讨如何在C/C++和Java之间使用...
本项目“C# AES加密解密小工具”提供了一个简单的AES ECB模式加密和解密实现,适用于对文本文件进行安全处理。 首先,AES是一种块密码,它将明文分成128位的块进行操作。ECB(Electronic Codebook)模式是最基础的...
本项目"大文件AES加密解密程序"就是针对这一需求而设计的,适用于VS2019开发环境,可能无法在较低版本的Visual Studio中正常运行。 AES,全称为Advanced Encryption Standard,是一种广泛使用的对称加密算法,以其...
AES加密解密轮转算法工具,最大支持256bit长度的密钥,明文支持HEX和字串。可供学习设计参考。
在C语言中实现AES加密解密是一项基础且重要的技能,特别是在嵌入式系统和低级别编程中。 AES的核心是一个名为Rijndael的密码,由比利时密码学家Joan Daemen和Vincent Rijmen设计。它的工作原理基于一系列的替换和...
AES加密解密验证工具(支持各种加密模式)
本篇文章将详细介绍如何在VB6环境中使用AES加密解密文本串和文件的DLL动态库。 首先,AES是一种块密码,它以128位的数据块为单位进行操作。AES支持三种不同的密钥长度:128位、192位和256位,其中128位是最常见的...
**AES加密解密程序概述** AES(Advanced Encryption Standard),即高级加密标准,是目前广泛使用的对称加密算法,因其高效性和安全性而备受青睐。MFC(Microsoft Foundation Classes)是微软提供的一套C++库,用于...
C# JAVA nodejs通用的AES加密解密算法,考虑到实际使用过程中由于客户端和服务端使用的语言不一样而又需要对数据进行加密和解密的情况,特此总结了C# JAVA nodejs通用的AES加密解密算法,供需要者参考。