package com.zit;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.PBEParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;
import org.apache.commons.codec.binary.Hex;
public class PBETest {
private static String src = "hello PBE";
public static void main(String[] args) {
jdkPBE();
}
public static void jdkPBE() {
try {
// 初始化盐 盐就是干扰的意思
SecureRandom random = new SecureRandom();
byte[] salt = random.generateSeed(8);// 指定为8位的盐 (盐就是干扰码,通过添加干扰码增加安全)
// 口令和密钥
String password = "lynu"; // 口令
PBEKeySpec pbeKeySpec = new PBEKeySpec(password.toCharArray());
SecretKeyFactory factory = SecretKeyFactory.getInstance("PBEWITHMD5andDES");
Key key = factory.generateSecret(pbeKeySpec); // 密钥
// 加密
PBEParameterSpec pbeParameterSpec = new PBEParameterSpec(salt, 100);// 参数规范,第一个参数是盐,第二个是迭代次数(经过散列函数多次迭代)
Cipher cipher = Cipher.getInstance("PBEWITHMD5andDES");
cipher.init(Cipher.ENCRYPT_MODE, key, pbeParameterSpec);
byte[] result = cipher.doFinal(src.getBytes());
System.out.println("jdk pbe加密: " + Base64.encodeBase64String(result));
// 解密
cipher.init(Cipher.DECRYPT_MODE, key, pbeParameterSpec);
result = cipher.doFinal(result);
System.out.println("jdk pbe解密:" + new String(result));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
PBE
最新推荐文章于 2022-05-09 10:22:02 发布