对称加密算法,就是公钥和私钥是一样的。这里主要有DES、3重DES、AES和PBE等,以下为各个对称加密算法的加解密使用方法,所有的类均引自JDK,无需另外导包(视情况可能需要阿帕奇的commons.codec包)。
其中AES为目前使用最多的,因为安全性上从未被破解过。
PBE是基于口令的加密,使用中要加入salt(盐--扰码)进行使用。
1、DES
import org.apache.commons.codec.binary.Hex;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import java.security.Key;
/**
* @Author Rhine
* @Date 2019/1/17 20:19
**/
public class ImoocDES {
private static String src="imooc security des";
public static void main(String[] args) {
jdkAES();
}
public static void jdkAES(){
try {
//生成key
KeyGenerator keyGenerator=KeyGenerator.getInstance("DES");
keyGenerator.init(56);
SecretKey secretKey=keyGenerator.generateKey();
byte[] byteKey=secretKey.getEncoded();
//key转化
DESKeySpec desKeySpec=new DESKeySpec(byteKey);
SecretKeyFactory factory=SecretKeyFactory.getInstance("DES");
Key convertSecretKey=factory.generateSecret(desKeySpec);
//加密
Cipher cipher=Cipher.ge