对称加密算法 之 AES 篇
密钥长度 |
默认 |
工作模式 |
填充方式 |
实现 |
128、192、256 |
128 |
ECB、CBC、PCBC、CTR、CTS、 CFB、CFB8到128、OFB8到128 |
NoPadding、 PKCS5Padding、 IOS10126Padding |
JDK(256位密钥需要获得无政策限制权限文件) |
同上 |
同上 |
同上 |
PKCS7Padding、 ZeroBytePadding |
BC |
package com.baikeyang.EncrptionProject;
import java.security.Key;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;
public class AESEncrption {
public static void main(String[] args) {
jdkAES();
}
static String str = "采用JDK实现对称加密AES算法";
public static void jdkAES(){
try {
// 生成Key
KeyGenerator generator = KeyGenerator.getInstance("AES");
generator.init(128);
SecretKey secretKey = generator.generateKey();
byte[] byteskey = secretKey.getEncoded();
// key的转换
Key key = new SecretKeySpec(byteskey, "AES");
// 加密
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte[] result = cipher.doFinal(str.getBytes());
System.out.println(Base64.encodeBase64String(result));
// 解密
cipher.init(Cipher.DECRYPT_MODE, key);
result = cipher.doFinal(result);
System.out.println(new String(result));
} catch (Exception e) {
e.printStackTrace();
}
}
}