一、AES、DES、TripleDES

package xxx.common.util;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.spec.SecretKeySpec;
import java.io.UnsupportedEncodingException;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Base64; /**
* Created by windwant on 2016/12/13.
*/
public class EncryptUtil {
private static final Logger logger = LoggerFactory.getLogger(EncryptUtil.class); private static final String DEFAULT_CHARSET = "UTF-8";
private static final String EMPTY_STR = "";
private static final int AES_KEY_SIZE = 16;//256/192/128~32/24/16 public static void main(String[] args) {
String tempkey = "!@#$%^&*()_+";
String ming = "at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_77]"; long begin = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
String en = tripleDesEncrypt(ming, tempkey);
String den = tripleDesDecrypt(en, tempkey);
}
long end = System.currentTimeMillis();
System.out.println("TripleDES: " + (end - begin));
System.out.println("TripleDES: " + (end - begin)/100000.0); begin = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
String en = desEncrypt(ming, tempkey);
String den = desDecrypt(en, tempkey);
}
end = System.currentTimeMillis();
System.out.println("DES: " + (end - begin));
System.out.println("DES: " + (end - begin)/100000.0); begin = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
String en = aesEncrypt(ming, tempkey);
String den = aesDecrypt(en, tempkey);
}
end = System.currentTimeMillis();
System.out.println("AES: " + (end - begin));
System.out.println("AES: " + (end - begin)/100000.0);
/*
100000次
key: !@#$%^&*()_+
src: at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_77]
TripleDES: 3831
TripleDES: 0.03831
DES: 845
DES: 0.00845
AES: 888
AES: 0.00888
*/
} private static final String ENCRYPT = "AES";
private static final String CIPHER = "AES/CBC/PKCS5Padding"; /**
* AES加密
* @param key 加密密钥
* @param src 加密内容
* @return 返回BASE64密文
*/
public static final String aesEncrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] bs = getAESResult(key, src.getBytes(DEFAULT_CHARSET), Cipher.ENCRYPT_MODE);
if (bs != null) {
return Base64.getEncoder().encodeToString(bs);
}
} catch (Exception e) {
logger.error(e.getMessage());
}
return src;
} /**
* AES解密
* @param key 解密密钥
* @param src 解密内容
* @return 明文
*/
public static final String aesDecrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] bs = getAESResult(key, Base64.getDecoder().decode(src.getBytes(DEFAULT_CHARSET)), Cipher.DECRYPT_MODE);
if (bs != null) {
return new String(bs, DEFAULT_CHARSET);
}
} catch (Exception e) {
e.printStackTrace();
logger.error(e.getMessage());
}
return src;
} /**
* AES加解密结果
* @param key 密钥
* @param textBytes 明文 密文 字节数组
* @param encryptMode 加密 解密
* @return
*/
private static byte[] getAESResult(String key, byte[] textBytes, final int encryptMode)
throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, BadPaddingException,
IllegalBlockSizeException, InvalidAlgorithmParameterException, UnsupportedEncodingException {
Key newKey = new SecretKeySpec(buildCLenKey(key, AES_KEY_SIZE), ENCRYPT);
Cipher cipher = Cipher.getInstance(ENCRYPT);
cipher.init(encryptMode, newKey, new SecureRandom());
return cipher.doFinal(textBytes);
} //定义加密算法,有DES、DESede(3DES)
private static final String ALGORITHM = "DESede";
// 算法名称/加密模式/填充方式
private static final String CIPHER_ALGORITHM_ECB = "DESede/ECB/PKCS5Padding";
/**
* TripleDES加密方法
* @param src
* @param key
* @return BASE64
*/
public static final String tripleDesEncrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] des = getTripleDESResult(key, src.getBytes(), Cipher.ENCRYPT_MODE);
if(des != null) {
return Base64.getEncoder().encodeToString(des);
}
} catch (Exception e) {
logger.error(e.getMessage());
}
return src;
} /**
* TripleDES解密函数
* @param src 密文的字节数组
* @param key 密钥
* @return String 明文
*/
public static final String tripleDesDecrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] srcb = Base64.getDecoder().decode(src);
byte[] des = getTripleDESResult(key, srcb, Cipher.DECRYPT_MODE);
return new String(des, DEFAULT_CHARSET);
} catch (Exception e) {
logger.error(e.getMessage());
}
return src;
} /**
* TripleDES加解密结果
* @param key 密钥
* @param textBytes 明文 密文 字节数组
* @param encryptMode 加密 解密
* @return
*/
private static byte[] getTripleDESResult(String key, byte[] textBytes, final int encryptMode)
throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, BadPaddingException,
IllegalBlockSizeException, InvalidAlgorithmParameterException, UnsupportedEncodingException {
Key newKey = new SecretKeySpec(buildCLenKey(key, 24), ALGORITHM);
Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM_ECB);
cipher.init(encryptMode, newKey, new SecureRandom());
return cipher.doFinal(textBytes);
} /**
* 根据字符串生成密钥字节数组
* @param keyStr 密钥字符串
* @param lgn 密钥长度
* @return 长度密钥字节数组
* @throws UnsupportedEncodingException
*/
private static byte[] buildCLenKey(String keyStr, int lgn) throws UnsupportedEncodingException {
byte[] key = new byte[lgn]; //声明一个24位的字节数组,默认里面都是0
byte[] temp = keyStr.getBytes("UTF-8"); //将字符串转成字节数组 ///执行数组拷贝
if (key.length > temp.length) {
//如果temp不够24位,则拷贝temp数组整个长度的内容到key数组中
System.arraycopy(temp, 0, key, 0, temp.length);
} else {
//如果temp大于24位,则拷贝temp数组24个长度的内容到key数组中
System.arraycopy(temp, 0, key, 0, key.length);
}
return key;
} private static final String DES_ALGORITHM = "DES";
public static final String DES_CIPHER_ALGORITHM = "DES";
/**
* DES 加密方法
* @param src
* @param key
* @return BASE64
*/
public static final String desEncrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] des = getDESResult(key, src.getBytes(), Cipher.ENCRYPT_MODE);
if(des != null) {
return Base64.getEncoder().encodeToString(des);
}
} catch (Exception e) {
logger.error(e.getMessage());
}
return src;
} /**
* DES解密函数
* @param src 密文的字节数组
* @param key 密钥
* @return String 明文
*/
public static final String desDecrypt(String src, String key) {
if(key == null || src == null){
return EMPTY_STR;
}
try {
byte[] srcb = Base64.getDecoder().decode(src);
byte[] des = getDESResult(key, srcb, Cipher.DECRYPT_MODE);
return new String(des, DEFAULT_CHARSET);
} catch (Exception e) {
logger.error(e.getMessage());
}
return src;
} private static byte[] getDESResult(String key, byte[] textBytes, final int encryptMode)
throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, BadPaddingException,
IllegalBlockSizeException, InvalidAlgorithmParameterException, UnsupportedEncodingException {
Key newKey = new SecretKeySpec(buildCLenKey(key, 8), DES_ALGORITHM);
Cipher cipher = Cipher.getInstance(DES_CIPHER_ALGORITHM);
cipher.init(encryptMode, newKey, new SecureRandom());
return cipher.doFinal(textBytes);
}
}

二、散列MD5、SHA

package xxx.common.util;

import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; /**
* 消息摘要 散列
* Created by windwant on 2016/12/14.
*/
public class MessageDigestUtil { public static void main(String[] args) {
System.out.println(md5("lilei"));
System.out.println(sha("lilei"));
} private static String md5(String data){
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(data.getBytes());
return new BigInteger(1, md.digest()).toString(16);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
} private static String sha(String data){
try {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(data.getBytes());
return new BigInteger(1, md.digest()).toString(16);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
} }

Java 加解密 AES DES TripleDes的更多相关文章

  1. java加解密算法--DES

    ECB import sun.misc.BASE64Decoder; import javax.crypto.*; import javax.crypto.spec.DESKeySpec; impor ...

  2. JAVA加解密之DES

    DES加密算法是一种分组密码,以64位为分组对数据加密,它的密钥长度是56位,加密解密用同一算法.DES加密算法是对密钥进行保密,而公开算法,包括加密和解密算法.这样,只有掌握了和发送方相同密钥的人才 ...

  3. 5.Java 加解密技术系列之 DES

    Java 加解密技术系列之 DES 序 背景 概念 基本原理 主要流程 分组模式 代码实现 结束语 序 前 几篇文章讲的都是单向加密算法,其中涉及到了 BASE64.MD5.SHA.HMAC 等几个比 ...

  4. 7.java 加解密技术系列之 AES

    java 加解密技术系列之 AES 序 概念 原理 应用 代码实现 结束语 序 这篇文章继续介绍对称加密算法,至于今天的主角,不用说,也是个厉害的角色 — — AES.AES 的出现,就是为了来替代原 ...

  5. 6. Java 加解密技术系列之 3DES

    Java 加解密技术系列之 3DES 序 背景 概念 原理 代码实现 结束语 序 上一篇文章讲的是对称加密算法 — — DES,这篇文章打算在 DES 的基础上,继续多讲一点,也就是 3 重 DES ...

  6. Java 加解密技术系列文章

    Java 加解密技术系列之 总结 Java 加解密技术系列之 DH Java 加解密技术系列之 RSA Java 加解密技术系列之 PBE Java 加解密技术系列之 AES Java 加解密技术系列 ...

  7. 160829、Java加解密与数字签名

    ** Java加解密 ** 实现方式:JDK实现,CC,BC JDK提供比较基础的底层的实现:CC提供一些简化的操作:BC提供补充 一.Base64加密 非常简单,加密解密就一个函数. 代码如下: 二 ...

  8. Java加解密与数字签名

    ** Java加解密 ** 实现方式:JDK实现,CC,BC JDK提供比较基础的底层的实现:CC提供一些简化的操作:BC提供补充 一.Base64加密 非常简单,加密解密就一个函数. 代码如下: 二 ...

  9. 8.Java 加解密技术系列之 PBE

    Java 加解密技术系列之 PBE 序 概念 原理 代码实现 结束语 序 前 边的几篇文章,已经讲了几个对称加密的算法了,今天这篇文章再介绍最后一种对称加密算法 — — PBE,这种加密算法,对我的认 ...

随机推荐

  1. docker创建私有仓库

    由于网速和大中华局域网效果,使得我们在DockerHub下载镜像的速度很慢,甚至一些国内的镜像仓库,也感觉速度不是很好.所以,很有必要在本地或者一个我们访问很快速的地方(自己的云服务器)搭建一套镜像仓 ...

  2. Nginx服务器之Nginx与tomcat结合访问jsp

    本文使用linux centos系统 本文概述: JSP是一种动态网页技术标准.使用的方式是在HTML文件中插入程序段和JSP标记,而形成JSP文件.使用JSP开发WEB应用可以跨平台开发.但jsp需 ...

  3. iOS开发之浅谈MVVM的架构设计与团队协作

    今天写这篇博客是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇博客的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦 ...

  4. HTML5 学习总结(二)——HTML5新增属性与表单元素

    一.HTML5新增属性 1.1.contextmenu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> & ...

  5. 跨域之同源策略 Same-origin policy

    同源策略是浏览器中最基本的隔离潜在恶意文件的安全策略,他限制了来自不同源(origin)的文档或脚本之间的相互作用. 何谓同源 在跨域之URL中介绍过一个URL的标准格式如下: 协议类型://服务器地 ...

  6. Android立体旋转动画实现与封装(支持以X、Y、Z三个轴为轴心旋转)

    本文主要介绍Android立体旋转动画,或者3D旋转,下图是我自己实现的一个界面 立体旋转分为以下三种: 1. 以X轴为轴心旋转 2. 以Y轴为轴心旋转 3. 以Z轴为轴心旋转--这种等价于andro ...

  7. Android来电监听和去电监听

    我觉得写文章就得写得有用一些的,必须要有自己的思想,关于来电去电监听将按照下面三个问题展开 1.监听来电去电有什么用? 2.怎么监听,来电去电监听方式一样吗? 3.实战,有什么需要特别注意地方? 监听 ...

  8. Javascript中关于cookie的那些事儿

    Javascript-cookie 什么是cookie? 指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密).简单点来说就是:浏览器缓存. cookie由什 ...

  9. sql将查询的结果集一次性插入到表变量中

    sql代码: declare @Subject table (--题目表变量 SubjectID int, Question nvarchar(MAX), CorrectAnswer ), Expla ...

  10. 设计模式(六)原型模式(Prototype Pattern)

    一.引言 在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创建这样的类实例,这未免会增加创建类的复杂度和耗费更多的内存空间,因为这样在 ...