网站首页 > java教程 正文
DES算法与DESede算法统称DES系列算法,DES算法是对称加密算法中的典型算法。
由于DES的密钥长度的不满足,才衍生出了DESede算法,对应中文“三重DES”。
对称加密会有 工作模式和填充方式两个概念
工作模式:ECB,CBC,CFB,OFB,CTR等
填充方式:NoPadding,PKCS5Padding,PKCS7Padding等
对于这两个概念大家可以在网上自行查阅。
DES算法密钥比较短,只有56位相对其它对称加密来说是不是特别的安全。由于DES算法具有半公开性质,被怀疑存在美国国家安全局安置的后门,受到各大密码学机构的强烈质疑。
Java8中对DES支持情况
密钥长度:56
工作模式:ECB,CBC,PCBC,CTR,CTS,CFB,CFB8至CFB128,OFB,OFB8至OFB128
填充方式:NoPadding,PKCS5Padding,ISO10126Padding。
一般我们使用对称加密算法时,我们是很少指定工作模式和填充方式的。所以这里也不必太在意这里的工作模式和填充方式。
代码示例:
每行代码都有注释,这里就不再叙述了,下面也给出文字代码,方便复制吧
package com.pack.security.des;
import java.nio.charset.Charset;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class DesMain {
/**
* @author xg
* @throws Exception
* @return byte[] 生成的密钥
* @desc
* 初始化对称加密DES密钥
*/
public static byte[] initDESKey() throws Exception {
KeyGenerator keyGenerator = KeyGenerator.getInstance("DES") ;
// 初始化长度
keyGenerator.init(56) ;
// 生成密钥
SecretKey secretKey = keyGenerator.generateKey() ;
// 获取密钥
return secretKey.getEncoded() ;
}
/**
* @author xg
* @param key 密钥字节数组
* @return Key({@link Key})
* @throws Exception
* @desc
* 将二进制数据转化成密钥
*/
public static Key convertDESKey(byte[] key) throws Exception {
// 实例化DES密钥材料
DESKeySpec desKeySpec = new DESKeySpec(key) ;
// 实例化密钥工厂
SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("DES") ;
// 生成密钥
return secretKeyFactory.generateSecret(desKeySpec) ;
}
/**
* @author xg
* @param data 要加密的数据
* @param secretKey(@link Key) 密钥
* @throws Exception
* @return byte[] 加密后的数据
* @desc
* 加密数据
*/
public static byte[] encodeByDES(byte[] data, Key key) throws Exception {
Cipher cipher = Cipher.getInstance("DES") ;
// 初始化,设置为加密模式
cipher.init(Cipher.ENCRYPT_MODE, key) ;
// 返回加密数据
return cipher.doFinal(data) ;
}
/**
*
* 解密数据
*
* @author xg
* @param data 加密的数据
* @param key 密钥
* @return byte[] 解密后的数据
* @throws Exception
*/
public static byte[] decodeByDES(byte[] data, Key key) throws Exception {
Cipher cipher = Cipher.getInstance("DES") ;
// 初始化,设置为解密模式
cipher.init(Cipher.DECRYPT_MODE, key) ;
// 返回解密数据
return cipher.doFinal(data) ;
}
public static void main(String[] args) throws Exception {
String message = "DES对称加密解密" ;
byte[] data = message.getBytes(Charset.forName("UTF-8")) ;
byte[] key = initDESKey() ;
String strKey = Base64.getEncoder().encodeToString(key) ;
String encryptedStr = Base64.getEncoder().encodeToString(encodeByDES(data, convertDESKey(key))) ;
System.out.println("加密后的数据:" + encryptedStr) ;
System.out.println("解密后数据为:" + new String(decodeByDES(Base64.getDecoder().decode(encryptedStr.getBytes("UTF-8")),
convertDESKey(Base64.getDecoder().decode(strKey.getBytes("UTF-8")))), "UTF-8")) ;
}
}
三重DES(DESede)
DESede也称为Triple DES,DESede是DES算法的改进版本,是的安全强度增强了,但同时该算法的处理速度变慢了,密钥的计算时间较长。
密钥长度:112或168位。
代码示例:
package com.pack.security.des;
import java.security.Key;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESedeKeySpec;
public class DESedeDemo {
// 密钥算法
public static final String ALGORITHM = "DESede" ;
// 加解密算法
public static final String CIPHER_ALGORITHM = "DESede/CBC/PKCS5Padding" ;
public static byte[] initKey() throws Exception {
// 实例化密钥生成器
KeyGenerator gen = KeyGenerator.getInstance(ALGORITHM) ;
// 设置密钥的长度 java8 支持 112和168位
gen.init(112) ;
// 生成密钥
SecretKey key = gen.generateKey() ;
return key.getEncoded() ;
}
/**
*
* 加密数据
*
* @author xg
* @param key 密钥
* @param datas 将要加密的数据
* @return String 返回Base64编码后的字符串
* @throws Exception
*/
public static String encodeData(Key key, byte[] datas) throws Exception {
// 实例化
Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM) ;
// 初始化当前加解密模式(这里加密)
cipher.init(Cipher.ENCRYPT_MODE, key) ;
// 生成加密后的数据
byte[] bs = cipher.doFinal() ;
return Base64.getEncoder().encodeToString(bs) ;
}
/**
*
* 解密数据
*
* @author xg
* @param key 密钥
* @param datas 加密后的数据
* @return String 返回解密后的数据
*/
public static String decodeData(Key key, byte[] datas) throws Exception {
Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM) ;
// 初始化,设置为解密模式
cipher.init(Cipher.DECRYPT_MODE, key) ;
// 返回解密数据
byte[] bs = cipher.doFinal(datas) ;
return Base64.getEncoder().encodeToString(bs) ;
}
/**
*
* 将字节数组转换成Key
*
* @author xg
* @param key
* @return Key
* @throws Exception
*/
public static Key toKey(byte[] key) throws Exception {
// 实例化密钥材料
DESedeKeySpec dks = new DESedeKeySpec(key) ;
// 实例化密钥工厂
SecretKeyFactory factory = SecretKeyFactory.getInstance(ALGORITHM) ;
// 生成密钥
return factory.generateSecret(dks) ;
}
public static void main(String[] args) throws Exception {
byte[] b = initKey() ;
Key key = toKey(b) ;
String datas = "DESede加密解密" ;
String encodeStr = encodeData(key, datas.getBytes()) ;
System.out.println("加密后的数据:" + encodeStr) ;
System.out.println("解密后的数据:" + decodeData(key, encodeStr.getBytes())) ;
}
}
猜你喜欢
- 2025-03-06 java中的锁及优化机制
- 2025-03-06 阿里Java一面:精通并发?那聊聊AQS框架及锁吧
- 2025-03-06 Java中各种锁的理解
- 2025-03-06 java aes-128-cbc密钥加SHA1PRNG加密,php&nodejs如何生成一样密钥
- 2025-03-06 Java基础——Java多线程(Lock接口详解)
- 2025-03-06 Java实现MD5加盐加密算法
- 2025-03-06 Java 加密解密PowerPoint文档
- 2025-03-06 Java实现数据加密:掌握DES CBC和ECB两种模式
- 2025-03-06 如何正确理解Java领域中锁机制,我们一般需要掌握哪些理论知识?
- 2025-03-06 Java中的锁是什么意思,有哪些分类?
你 发表评论:
欢迎- 最近发表
-
- Java常量定义防暴指南:从"杀马特"到"高富帅"的华丽转身
- Java接口设计原则与实践:优雅编程的艺术
- java 包管理、访问修饰符、static/final关键字
- Java工程师的代码规范与最佳实践:优雅代码的艺术
- 编写一个java程序(编写一个Java程序计算并输出1到n的阶乘)
- Mycat的搭建以及配置与启动(mycat部署)
- Weblogic 安装 -“不是有效的 JDK Java 主目录”解决办法
- SpringBoot打包部署解析:jar包的生成和结构
- 《Servlet》第05节:创建第一个Servlet程序(HelloSevlet)
- 你认为最简单的单例模式,东西还挺多
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)