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