java加解密算法--DES

  • ECB
import javax.crypto.*;
import javax.crypto.spec.DESKeySpec;
import java.io.IOException;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.spec.InvalidKeySpecException;

public class Decrypt {

    public static byte[] initSecretKey() throws NoSuchAlgorithmException {
        //指定算法秘钥生成器
        KeyGenerator kg = KeyGenerator.getInstance("des");
        //初始化秘钥生成器,使其具有确定到秘钥大小
        kg.init(56);
        //生成秘钥
        SecretKey secretkey = kg.generateKey();
        return secretkey.getEncoded();
    }

    public static byte[] encrypt(byte[] key, String src) throws InvalidKeyException, NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, BadPaddingException, IllegalBlockSizeException, InvalidAlgorithmParameterException {
        //jdk初始化秘钥转化des秘钥
        DESKeySpec desKeySpec = new DESKeySpec(key);
        //创建秘钥工厂实例
        SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("des");
        //生成秘钥
        SecretKey secretKey = secretKeyFactory.generateSecret(desKeySpec);

        /**
         * 加密实际操作Cipher
         */
        //创建Cipher对象
        Cipher cipher = Cipher.getInstance("des/cbc/PKCS5Padding");
        //初始化Cipher
        cipher.init(Cipher.ENCRYPT_MODE,secretKey);
        byte[] data = src.getBytes();
        //加密
        byte[] encryptedData = cipher.doFinal(data);
        return encryptedData;

    }

    public static void main(String[] args) throws NoSuchAlgorithmException, IllegalBlockSizeException, NoSuchPaddingException, BadPaddingException, InvalidKeySpecException, InvalidKeyException, IOException, InvalidAlgorithmParameterException {
        //byte[] secretKey = initSecretKey();
        //或者代码中约定key
        String key = "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4";
        byte[] secretKey = key.getBytes();
        String str = "abc";
        byte[] encryptedData = encrypt(secretKey, str);
        String decrypteData = decrypt(secretKey, encryptedData);
    }

    public static String decrypt(byte[] key,byte[] encryptedData) throws InvalidKeyException, NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, BadPaddingException, IllegalBlockSizeException, InvalidAlgorithmParameterException {
        //jdk初始化秘钥转化des秘钥
        DESKeySpec desKeySpec = new DESKeySpec(key);
        //创建秘钥工厂实例
        SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("des");
        //生成秘钥
        SecretKey secretKey = secretKeyFactory.generateSecret(desKeySpec);
        /** * 解密实际操作Cipher */
        //创建Cipher对象
        Cipher cipher = Cipher.getInstance("des/cbc/PKCS5Padding");
        //初始化Cipher
        cipher.init(Cipher.DECRYPT_MODE,secretKey);
        //加密
        byte[] dencryptedData = cipher.doFinal(encryptedData);
        return new String(dencryptedData);
    }
}   
  • CBC

与ECB差别,加解密都要使用初始化向量,且初始化向量一致   

import javax.crypto.*;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.IvParameterSpec;
import java.io.IOException;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.spec.InvalidKeySpecException;

public class encrypt {

    public static byte[] initSecretKey() throws NoSuchAlgorithmException {
        //指定算法秘钥生成器
        KeyGenerator kg = KeyGenerator.getInstance("des");
        //初始化秘钥生成器,使其具有确定到秘钥大小
        kg.init(56);
        //生成秘钥
        SecretKey secretkey = kg.generateKey();
        return secretkey.getEncoded();
    }

    public static byte[] encrypt(byte[] key, String src,byte[] keyIv) throws InvalidKeyException, NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, BadPaddingException, IllegalBlockSizeException, InvalidAlgorithmParameterException {
        //jdk初始化秘钥转化des秘钥
        DESKeySpec desKeySpec = new DESKeySpec(key);
        //创建秘钥工厂实例
        SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("des");
        //生成秘钥
        SecretKey secretKey = secretKeyFactory.generateSecret(desKeySpec);

        /**
         * 加密实际操作Cipher
         */
        //创建Cipher对象
        Cipher cipher = Cipher.getInstance("des/cbc/PKCS5Padding");
        //创建初始化向量
        IvParameterSpec iv = new IvParameterSpec(keyIv);
        //初始化Cipher
        cipher.init(Cipher.ENCRYPT_MODE,secretKey,iv);
        byte[] data = src.getBytes();
        //加密
        byte[] encryptedData = cipher.doFinal(data);
        return encryptedData;

    }

    public static void main(String[] args) throws NoSuchAlgorithmException, IllegalBlockSizeException, NoSuchPaddingException, BadPaddingException, InvalidKeySpecException, InvalidKeyException, IOException, InvalidAlgorithmParameterException {
        //byte[] secretKey = initSecretKey();
        //或者代码中约定key
        String key = "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4";
        byte[] secretKey = key.getBytes();
        byte[] iv = {1, 2, 3, 4, 5, 6, 7, 8};
        String str = "abc";
        byte[] encryptedData = encrypt(secretKey, str,iv);
        String decrypteData = decrypt(secretKey, encryptedData,iv);
    }

    public static String decrypt(byte[] key,byte[] encryptedData,byte[] keyIv) throws InvalidKeyException, NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, BadPaddingException, IllegalBlockSizeException, InvalidAlgorithmParameterException {
        //jdk初始化秘钥转化des秘钥
        DESKeySpec desKeySpec = new DESKeySpec(key);
        //创建秘钥工厂实例
        SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("des");
        //生成秘钥
        SecretKey secretKey = secretKeyFactory.generateSecret(desKeySpec);
        /** * 解密实际操作Cipher */
        //创建Cipher对象
        Cipher cipher = Cipher.getInstance("des/cbc/PKCS5Padding");
        //创建初始化向量
        IvParameterSpec iv = new IvParameterSpec(keyIv);
        //初始化Cipher
        cipher.init(Cipher.DECRYPT_MODE,secretKey,iv);
        //加密
        byte[] dencryptedData = cipher.doFinal(encryptedData);
        return new String(dencryptedData);
    }
}

  

DES与3DES同样到工作模式和填充模式相同,它们加解密区别:

  • jdk初始化秘钥转化des秘钥

  DES:

DESKeySpec desKeySpec = new DESKeySpec(key);

  3DES:

DESedeKeySpec spec = new DESedeKeySpec(key);
  • 创建秘钥工厂实例  

  DES:

SecretKeyFactory secretKeyFactory = SecretKeyFactory.getInstance("des");

  3DES:

SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede");
  • 密钥长度

  DES:56

  3DES:168

posted @ 2020-02-11 22:36  Ivy_Xu  阅读(375)  评论(0编辑  收藏  举报