AES算法加密java实现

package cn.itcast.coderUtils;

import java.security.Key;

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.SecretKeySpec;

public class AESCoder {

public static final String KEY_ALGORITHM = "AES";

/**

* 加密、解密/ 工作模式/ 填充方式

*/

public static final String CIPHER_ALGORITHM = "AES/ECB/PKCS5Padding";

/**

* 转换秘钥

* @param key 二进制秘钥

* @return Key 秘钥

* @throws Exception

*/

private static Key toKey(byte[] key) throws Exception {

//实例化AES秘钥材料

SecretKey  secretKey = new SecretKeySpec(key, KEY_ALGORITHM);

return secretKey;

}

/**

* @param data 带解密数据

* @param key 秘钥

* @return byte[] 解密数据

* @throws Exception

*/

public static byte[] decrypt(byte[] data, byte[] key) throws Exception {

//还原秘钥

Key k = toKey(key);

//实例化

Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);

//初始化,设置解密模式

cipher.init(Cipher.DECRYPT_MODE, k);

//执行操作

return cipher.doFinal(data);

}

/**

* 加密

* @param data  带加密数据

* @param key 秘钥

* @return byte[] 加密数据

* @throws Exception

*/

public static byte[] encrypt(byte[] data, byte[] key) throws Exception {

//还原秘钥

Key k = toKey(key);

//实例化

Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);

//初始化,设置加密模式

cipher.init(Cipher.ENCRYPT_MODE, k);

//执行操作

return cipher.doFinal(data);

}

/**

* 生成秘密秘钥

* java7 只支持56位密钥

* Bouncy Castle 支持64位秘密

* @return  二进制秘钥

* @throws Exception

*/

public static byte[] initKey() throws Exception {

/**

* 实例化秘钥生成器

*如要使用64位秘钥需要替换为 KeyGenerator.getInstance(CIPHER__ALGORITHM, "BC");

*"BC"是Bouncy Castle安全提供者的缩写。

*/

KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);

//初始化秘钥生成器

kg.init(128);

//生成秘密秘钥

SecretKey secretKey = kg.generateKey();

//获得秘钥的二进制编码形式

return secretKey.getEncoded();

}

}

上述代码实现相对通用,可用于DES,DESede(3DES),RC2,RC4等算法都可以参照上述代码实现,只需对算法名称稍作调整即可。

测试用例代码:

package cn.itcast.testUtils;

import org.apache.commons.codec.binary.Base64;

import org.junit.Test;

import com.sun.enterprise.security.auth.login.AssertedCredentials;

import cn.itcast.coderUtils.DESCoder;

public class AESCoderTest {

@Test

public void testAES() throws Exception {

String inputStr = "AES";

byte[] inputData = inputStr.getBytes();

System.out.println("原文:\t"+ inputStr);

byte[] key = DESCoder.initKey();

System.out.println("秘钥:\t" + Base64.encodeBase64String(key));

//加密

inputData = DESCoder.encrypt(inputData, key);

System.out.println("加密后:\t" + Base64.encodeBase64String(inputData));

byte[] outputDtat = DESCoder.decrypt(inputData, key);

String outputStr = new String(outputDtat);

System.out.println("解密后:\t" + outputStr);

Boolean bool = inputStr.equals(outputStr);

System.out.println(bool);

}

}

时间: 2024-10-05 04:58:21

AES算法加密java实现的相关文章

JAVA实现AES的加密和解密算法

原文 JAVA实现AES的加密和解密算法 import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; /** * AES 是一种可逆加密算法,对用户的敏感信息加密处理 * 对原始数据进行AES加密后,在进行Base6

Java加密AES算法及spring中应用

开门见山直接贴上代码 1.AESUtil加密解密工具类 import java.security.Key; import java.security.SecureRandom; import java.util.Base64; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; /** * @description: AES加密工具类 * @author: maojialong * @date: 2017年11月7日 上午1

JAVA中AES对称加密和解密

AES对称加密和解密 package demo.security; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.util.Ba

AES算法,DES算法,RSA算法JAVA实现

1     AES算法 1.1    算法描述 1.1.1      设计思想 Rijndael密码的设计力求满足以下3条标准: ① 抵抗所有已知的攻击. ② 在多个平台上速度快,编码紧凑. ③ 设计简单. 当前的大多数分组密码,其轮函数是Feistel结构. Rijndael没有这种结构. Rijndael轮函数是由3个不同的可逆均匀变换 1.1.2      密码说明 严格地说,AES和Rijndael加密法并不完全一样(虽然在实际应用中二者可以互换),因为Rijndael加密法可以支持更大

Android接口安全 - RSA+AES混合加密方案

转载请注明出处: http://blog.csdn.net/aa464971/article/details/51034462 本文以Androidclient加密提交数据到Java服务端后进行解密为样例. 生成RSA公钥和密钥的方法请參考: http://blog.csdn.net/aa464971/article/details/51035200 Android端的加密思路须要4步: 1.生成AES密钥: 2.使用RSA公钥加密刚刚生成的AES密钥: 3.再使用第1步生成的AES密钥,通过A

AES对称加密和解密

package demo.security; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.util.Base64; impor

AES高级加密标准简析

1 AES高级加密标准简介 1.1 概述 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用.经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准.2006年,高级加密标准已然成为对称密钥加密中最流行的算法

Vue AES+MD5加密 后台解密

前端VUE vue项目中安装crypto-js npm install crypto-js --save-dev CryptoJS (crypto.js) 为 JavaScript 提供了各种各样的加密算法.目前已支持的算法包括: MD5 SHA-1 SHA-256 AES 新建aes.js \src\utils\目录下新建aes.js文件 import Vue from 'vue' import CryptoJS from 'crypto-js' // AES-128-CBC偏移量 const

AES算法简介

AES算法简介 一. AES的结构 1.总体结构 明文分组的长度为128位即16字节,密钥长度可以为16,24或者32字节(128,192,256位).根据密钥的长度,算法被称为AES-128,AES-192或者AE-256. 2.明文密钥组织方式 3.一些相关的的术语定义和表示 • 状态(State):密码运算的中间结果称为状态. • State的表示:状态用以字节为基本构成元素的矩阵阵列来表示,该阵列有4行,列数记为Nb. Nb=分组长度(bits)÷ 32.Nb可以取的值为4,对应的分组长