欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

3DES加/解密

时间:2023-04-16
文章目录

前言一、算法介绍二、使用步骤

1.引入库2.静态变量3.加密4.解密5.验证


前言

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


一、算法介绍

3DES又称Triple DES,是DES加密算法的一种模式,它使用2条不同的56位的密钥对数据进行三次加密。
数据加密标准(DES)是美国的一种由来已久的加密标准,它使用对称密钥加密法,并于1981年被ANSI组织规范为ANSI X.3.92。DES使用56位密钥和密码块的方法,而在密码块的方法中,文本被分成64位大小的文本块然后再进行加密。比起最初的DES,3DES更为安全。3DES(即TripleDES)是DES向AES过渡的加密算法(1999年,NIST将3-DES指定为过渡的加密标准),加密算法,其具体实现如下:设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的密钥,P代表明文,C代表密文,这样:
3DES加密过程为:C=Ek3(Dk2(Ek1§)) 3DES解密过程为:P=Dk1(EK2(Dk3©)) 二、使用步骤 1.引入库

import com.sun.org.apache.xml.internal.security.utils.base64;import org.apache.commons.lang3.StringUtils;import javax.crypto.Cipher;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESedeKeySpec;import javax.crypto.spec.IvParameterSpec;import java.security.Key;

2.静态变量

private final static String encoding = "UTF-8";

3.加密

public static String encode(String plainText, String secretKey, String iv) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(secretKey.getBytes()); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.ENCRYPT_MODE, deskey, ips); byte[] encryptData = cipher.doFinal(plainText.getBytes(encoding)); return base64.encode(encryptData); }

4.解密

public static String decode(String encryptText, String secretKey, String iv) throws Exception { if (StringUtils.isBlank(encryptText) || StringUtils.isBlank(secretKey)) { return ""; } Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(secretKey.getBytes()); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede/CBC/NoPadding"); //desede/CBC/NoPadding 无填充 desede/CBC/PKCS5Padding 加密需要填充,解密一般加不加都结果一致 IvParameterSpec ips = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.DECRYPT_MODE, deskey, ips); byte[] decryptData = cipher.doFinal(base64.decode(encryptText)); return new String(decryptData, encoding).trim(); }

5.验证

public static void main(String[] args) { try { String key = "qwertyuiopasdfghqwertyui"; String iv = "qwertyui";//IV length must be 8 bytes long //加密 String encryptStr = encode("test", key, iv); System.out.println("密文: " + encryptStr); //解密 String decryptStr = decode(encryptStr, key, iv); System.out.println("明文: " + decryptStr); } catch (Exception e) { e.printStackTrace(); } }

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。