package com.encrypt.hello;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class AES {
private final static String algorithm = "AES";
/**
* BASE64解密
*
* @param key
* @return
* @throws Exception
*/
public static byte[] decryptBASE64(String key) throws Exception {
return (new BASE64Decoder()).decodeBuffer(key);
}
/**
* BASE64加密
*
* @param key
* @return
* @throws Exception
*/
public static String encryptBASE64(byte[] key) throws Exception {
return (new BASE64Encoder()).encodeBuffer(key);
}
/**
* 加密
*
* @param data
* @param rawKey
* @return
* @throws Exception
*/
public static String encrypt(String data, String rawKey) {
byte[] key = rawKey.getBytes();
// Instantiate the cipher
try {
SecretKeySpec skeySpec = new SecretKeySpec(key, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(data.getBytes());
return encryptBASE64(encrypted);
} catch (Exception e) {
// App.log.info("AES", "获取加密串出错," + e.getMessage());
return "";
}
}
/**
* 解密
*
* @param encrypted
* @param rawKey
* @return
*/
public static String decrypt(String encrypted, String rawKey) {
try {
byte[] tmp = decryptBASE64(encrypted);
byte[] key = rawKey.getBytes();
SecretKeySpec skeySpec = new SecretKeySpec(key, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] decrypted = cipher.doFinal(tmp);
return new String(decrypted);
} catch (Exception e) {
// App.log.info("AES", "获取解密串出错," + e.getMessage());
return "";
}
}
public static void main(String[] args) throws Exception {
String data = "00";
String key = "0123456789123456";
System.out.println("密钥为:" + key);
long lStart = System.currentTimeMillis();
// 加密
String encrypted = encrypt(data, key);
System.out.println("原文:" + data);
System.out.println("加密后:" + encrypted);
long lUseTime = System.currentTimeMillis() - lStart;
System.out.println("加密耗时:" + lUseTime + "毫秒");
System.out.println();
// 解密
lStart = System.currentTimeMillis();
String decrypted = decrypt(encrypted, key);// 解密串
System.out.println("解密后: " + decrypted);
lUseTime = System.currentTimeMillis() - lStart;
System.out.println("解密耗时:" + lUseTime + "毫秒");
}
}
分享到:
相关推荐
主要介绍了java使用Hex编码解码实现Aes加密解密功能,结合完整实例形式分析了Aes加密解密功能的定义与使用方法,需要的朋友可以参考下
java AES加密解密,使用 CBC 解密模式,EncryptByAes Aes加密 后 base64 再加 DecryptByAes Aes 解密,对 PKCS7 填充的数据进行反填充,对数据进行 PKCS7 填充 使用 CBC 解密模式, // aesDecrypt 解密 public ...
主要介绍了java实现的AES加密算法,结合完整实例形式分析了AES加密类的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
在工作中会经常遇到密码加密,URL传参要进行加密,在此我参照一个例子将用java实现的AES加解密程序用实例写出。JS实现AES-GCM加密,java实现AES-GCM解密
主要介绍了Java使用AES加密和解密的实例详解的相关资料,需要的朋友可以参考下
主要介绍了Java实现的对称加密算法AES,结合实例形式分析了对称加密算法AES的定义、特点、用法及使用场景,需要的朋友可以参考下
主要介绍了JAVA中AES加密方法,实例分析了java中AES加密与解密的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
java代码实例 AES加密解密 Base64加密解密
包括java自定义加密解密实例,异或加密解密实例,AES加密解密,DES加密解密 对文件加密建议使用DES方式 技术学习交流:635278789
各种加密的demo和实例效果,包括java,安卓,iOS,.NET,等加密demo
AES 加密 解密 128位 java C# JAVASCRIPT PHP 实例
主要介绍了Java实现的AES256加密解密功能,结合完整实例形式分析了Java实现AES256加密解密功能的步骤与相关操作技巧,需要的朋友可以参考下
完整测试使用AES加密实例,避免重复new生成多个BouncyCastleProvider对象,因为GC回收不了,会造成内存溢出,只在第一次调用decrypt()方法时才new 对象 AES-128加密 内容包含:AES实例代码; bcprov-jdk16-1.46.jar...
AES java版加密和解密文件。里面包含实例。
主要介绍了java使用RSA与AES加密解密的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
java zip 压缩(解压)并加密、AES加密、项目实例、含有相关jar包。由jsp+servlet实现。jdk1.5/Myeclipse8.5开发,Tomcat6测试通过
可以加密文件或文本,已编写成类,可以很方便的放入自己的程序中,如编译成dll应用范围更大(web asp php java vb vc excel word等都可以方便调用)。
java源码Whitebox-crypto-AES-java 白盒加密 AES 实现。 该存储库包含由等人引入的完整白盒 -128 方案的 Java 实现。 它实现/使用输入/输出编码、混合双射、外部编码。 实现代码包含 Chow 的白盒 AES 方案实例生成器...
在对称加密部分,介绍了AES加密算法及其在Java中的实现方法,包括加密和解密过程。在非对称加密部分,以RSA加密算法为例,介绍了如何在Java中实现非对称加密,包括密钥生成、公钥和私钥的获取以及加密和解密过程。...
主要介绍了Java实现AES/CBC/PKCS7Padding加解密的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下