前言

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.加密

		/**
         * 方法描述:3DES加密
         * @author hyang
         *
         * @param plainText  明文
         * @param secretKey  密钥
         * @param iv         加密向量
         * @return String    密文
         * @throws Exception
         */
        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.解密

		/**
         * 方法描述: 3DES解密
         * @author hyang
         *
         * @param encryptText 密文
         * @param secretKey   密钥
         * @param iv          加密向量
         * @return String     明文
         * @throws Exception
         */
        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.验证

		/**
         * 方法描述:测试方法
         * @author hyang
         *
         * @param args
         */
        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();
            }
        }

在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐