1. 简单介绍

3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次DES加密算法。由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解;3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法。

2. 对称加密

2.1 介绍

对称密码算法是当今应用范围最广,使用频率最高的加密算法。它不仅应用于软件行业,在硬件行业同样流行。各种基础设施凡是涉及到安全需求,都会优先考虑对称加密算法。对称密码算法的加密密钥和解密密钥相同,对于大多数对称密码算法,加解密过程互逆。

  • 特点:算法公开、计算量小、加密速度快、加密效率高。

  • 弱点:双方都使用同样密钥,安全性得不到保证。

对称密码有流密码和分组密码两种,但是现在普遍使用的是分组密码:

2.2 分组密码工作模式

  • ECB:电子密码本(最常用的,每次加密均产生独立的密文分组,并且对其他的密文分组不会产生影响,也就是相同的明文加密后产生相同的密文)
  • CBC:密文链接(常用的,明文加密前需要先和前面的密文进行异或运算,也就是相同的明文加密后产生不同的密文)
  • CFB:密文反馈
  • OFB:输出反馈
  • CTR:计数器

2.3 常用对称密码:

  • DES(Data Encryption Standard,数据加密标准)
  • 3DES(Triple DES、DESede,进行了三重DES加密的算法)
  • AES(Advanced Encryption Standard,高级数据加密标准,AES算法可以有效抵制针对DES的攻击算法

3. DES / 3DES / AES 三种算法实现

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec; import com.newland.csf.common.business.IBusinessComponent; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.nio.charset.StandardCharsets; /**
*
*
*
*/
public class TripleDes { //指定要使用的算法 DES / 3DES / AES 分别对应的 值为: DES / DESede / AES
public static final String ALGORITHM_3DES = "DESede"; /**
* 解密算法
* @param hexString 密文手机号
* @param skString 密钥
* @return
* @throws Exception
*/
public static String tripleDesDecrypt(String skString, String hexString) throws Exception {
SecretKey secretKey = new SecretKeySpec(fromHexString(skString), ALGORITHM_3DES);
byte[] input = fromHexString(hexString);
byte[] output = tripleDesDecryptBytes(secretKey, input);
return new String(output, StandardCharsets.UTF_8);
} /**
* 加密算法
* @param hexString 明文手机号
* @param skString 密钥
* @return
* @throws Exception
*/
public static String tripleDesEncrypt(String skString, String hexString) throws Exception {
SecretKey secretKey = new SecretKeySpec(fromHexString(skString), ALGORITHM_3DES);
byte[] output = tripleDesEncryptBytes(secretKey, hexString.getBytes(StandardCharsets.UTF_8));
return bytes2Hex(output, false);
} public static String bytes2Hex(byte[] bytes, boolean upperCase) {
if (bytes == null || bytes.length <= 0) {
return "";
}
StringBuilder sb = new StringBuilder();
for (byte b : bytes) {
sb.append(String.format("%02x", b));
}
return upperCase ? sb.toString().toUpperCase() : sb.toString();
} public static byte[] fromHexString(final String hexString) {
if ((hexString.length() % 2) != 0) {
throw new IllegalArgumentException(
"hexString.length not is an even number");
} final byte[] result = new byte[hexString.length() / 2];
final char[] enc = hexString.toCharArray();
StringBuilder sb = new StringBuilder(2);
for (int i = 0; i < enc.length; i += 2) {
sb.delete(0, sb.length());
sb.append(enc[i]).append(enc[i + 1]);
result[i / 2] = (byte) Integer.parseInt(sb.toString(), 16);
}
return result;
} public static byte[] tripleDesEncryptBytes(SecretKey secretKey, byte[] src) throws Exception {
Cipher c1 = Cipher.getInstance(ALGORITHM_3DES);
c1.init(Cipher.ENCRYPT_MODE, secretKey);
return c1.doFinal(src);
} public static byte[] tripleDesDecryptBytes(SecretKey secretKey, byte[] src) throws Exception {
Cipher c1 = Cipher.getInstance(ALGORITHM_3DES);
c1.init(Cipher.DECRYPT_MODE, secretKey);
return c1.doFinal(src);
} /**
* 加密文件
* @param skString
* @param srcFilePath
* @param desFilePath
* @throws Exception
*/
public static void tripleDesEncryptFile(String skString,String srcFilePath,String desFilePath) throws Exception {
Cipher cipher = Cipher.getInstance(ALGORITHM_3DES);
SecretKey secretKey = new SecretKeySpec(fromHexString(skString), ALGORITHM_3DES);
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
writeFile(cipher,srcFilePath,desFilePath);
} /**
* 解密文件
* @param skString
* @param srcFilePath
* @param desFilePath
* @throws Exception
*/
public static void tripleDesDecryptFile(String skString,String srcFilePath,String desFilePath) throws Exception {
Cipher cipher = Cipher.getInstance(ALGORITHM_3DES);
SecretKey secretKey = new SecretKeySpec(fromHexString(skString), ALGORITHM_3DES);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
writeFile(cipher,srcFilePath,desFilePath);
} private static void writeFile(Cipher cipher,String srcFilePath,String desFilePath) throws Exception{
byte[] buff = new byte[512];
byte[] temp = null;
int len = 0;
try (FileInputStream fis = new FileInputStream(new File(srcFilePath));
FileOutputStream fos = new FileOutputStream(new File(desFilePath))) {
while ((len = fis.read(buff)) > 0) {
temp = cipher.update(buff, 0, len);
fos.write(temp);
}
temp = cipher.doFinal();
if (temp != null) {
fos.write(temp);
}
}
}
}

本文由AnonyStar 发布,可转载但需声明原文出处。

仰慕「优雅编码的艺术」 坚信熟能生巧,努力改变人生

欢迎关注微信公账号 :云栖简码 获取更多优质文章

更多文章关注笔者博客 :云栖简码

DES/3DES/AES 三种对称加密算法实现的更多相关文章

  1. Java利用DES/3DES/AES这三种算法分别实现对称加密

    转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ...

  2. DES、3DES、AES、PBE对称加密算法实现及应用

    1.对称加密算法概述 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文和加密密钥一起经过特殊加密算法处理后,使其变成复杂的加密密文发送出去.收信方收到密文后,若想解读原文 ...

  3. DES,3DES,AES这三种对称密钥的区别与联系

    DES:Data Encryption Standard(数据加密标准,又美国国密局,选中的IBM的方案,密钥长度为56,标准提出是要使用64位长的密钥,但是实际中DES算法只用了64位中的56位密钥 ...

  4. java-信息安全(二)-对称加密算法DES,3DES,AES,Blowfish,RC2,RC4

    概述 信息安全基本概念: DES(Data Encryption Standard,数据加密标准) 3DES(Triple DES,三重数据加密算法(TDEA,Triple Data Encrypti ...

  5. 浅析DES与AES、RSA三种典型加密算法的比较

    DES与AES的比较 自DES 算法公诸于世以来,学术界围绕它的安全性等方面进行了研究并展开了激烈的争论.在技术上,对DES的批评主要集中在以下几个方面: 1.作为分组密码,DES 的加密单位仅有64 ...

  6. DES/3DES/AES区别

    公元前400年,古希腊人发明了置换密码.1881年世界上的第一个电话保密专利出现.在第二次世界大战期间,德国军方启用“恩尼格玛”密码机,密码学在战争中起着非常重要的作用. DES 1977年1月,美国 ...

  7. [android]DES/3DES/AES加密方式

    DES 支持8位加密解密,3Des支持24位,Aes支持32位.3Des是Des算法做三次.位数的单位是字节byte.不是bits. 3Des是把24位分成3组.第一组八位用来加密,第二组8位用于解密 ...

  8. 对加密的了解(DES/3DES/AES区别 )

    DES 1977年1月,美国政府颁布:采纳IBM公司设计的方案作为非机密数据的正式. 目前在国内,随着三金工程尤其是金卡工程的启动,DES算法在POS.ATM.磁卡及智能卡(IC卡).加油站.高速公路 ...

  9. 常用加密算法的Java实现总结(二) ——对称加密算法DES、3DES和AES

    1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文(原始数据)和加密密钥(mi yue)一起经过特殊加密算法处理后,使其变成复杂的加密密文发 ...

随机推荐

  1. DPDK Hash Library原理(学习笔记)

    0 前言 本文主要翻译至DPDK的官方编程指南,在谷歌翻译的基础上根据自己的理解做了一些修改.网上搜索的很多中文翻译大多是翻译后直接黏贴上来,有时候连语句都读不通.希望本文能够对你有所帮助. 1 介绍 ...

  2. 获取访问用户的客户端IP(适用于公网与局域网).

     /**   * 获取访问用户的客户端IP(适用于公网与局域网).   */   public final String getIpAddr(final HttpServletRequest requ ...

  3. 自定义spring-boot-starter

    需求背景: Springboot是Spring旗下优秀的子项目之一,其核心理念之一:约定优于配置.通过自动化的配置极大的提升了我们的开发效率,目前已集成诸多组件的starter起步依赖,帮助我们更加快 ...

  4. wxss--外联样式与内联样式

    外联样式 有样式表a.wxss和index.wxss如下: /**a.wxss**/ .container1{ border: 1px solid #000; } /**index.wxss**/ . ...

  5. 15-2 insert语句介绍

    create table TblClass ( tClassId ,) primary key, tClassName ) ) --向班级表中插入一条记录 --insert into 表名(列1,列2 ...

  6. 微信小程序制作个人简历

    使用微信小程序云开发制作自己的个人简历,简单高效. 首先需要了解小程序的基本结构以及云开发模式,及一些css样式基础. 使用小程序云数据库.vant组件库实现简历内容. 最终效果如下: 首先申请个人微 ...

  7. vi和软件安装

    一 vi编辑器简介 vim     全屏幕纯文本编辑器 二  vim使用 1   vi 模式 vi  文件名 命令模式 输入模式 末行模式 命令---->输入  a:追加  i:插入  o:打开 ...

  8. ThreadLocal原理分析

    本文结构 ThreadLocal简介 (简要说明ThreadLocal的作用) ThreadLocal实现原理(说明ThreadLocal的常用方法和原理) ThreadLocalMap的实现 (说明 ...

  9. [Objective-C] 013_文件系统(File System)

    在前面三篇关于数据持久化,我们都用涉及到文件(plist文件,数据库文件),它们都是把它们存储在document目录下.iOS的文件机制是沙盒机制,应用只能访问自己应用目录下的文件.iOS应用产生的内 ...

  10. 一篇文章看清楚 Linux 的职业发展方向

    手机.汽车.甚至宇宙飞船,在今天的科技世界中,你几乎到处都能看到 Linux 的身影.前两天 SpaceX 成功将宇航员送入太空的猎鹰9号火箭与龙飞船用的也是 Linux的操作系统.身处与 Linux ...