要使用AES加密的密钥,可以使用Java中的javax.crypto包提供的功能。下面是一个示例代码,展示了如何生成AES加密密钥并使用它进行加密和解密:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
public class AesEncryptionExample {
public static void main(String[] args) throws Exception {
String plainText = "Hello, World!";
// 生成AES密钥
SecretKey secretKey = generateAesKey();
// 加密
byte[] encryptedText = encrypt(plainText, secretKey);
System.out.println("Encrypted Text: " + Base64.getEncoder().encodeToString(encryptedText));
// 解密
String decryptedText = decrypt(encryptedText, secretKey);
System.out.println("Decrypted Text: " + decryptedText);
}
public static SecretKey generateAesKey() throws Exception {
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
keyGenerator.init(128); // 可以选择128、192或256位密钥大小
return keyGenerator.generateKey();
}
public static byte[] encrypt(String plainText, SecretKey secretKey) throws Exception {
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
return cipher.doFinal(plainText.getBytes());
}
public static String decrypt(byte[] encryptedText, SecretKey secretKey) throws Exception {
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedBytes = cipher.doFinal(encryptedText);
return new String(decryptedBytes);
}
}
这个示例演示了如何使用AES加密密钥进行文本的加密和解密。首先,使用generateAesKey
方法生成一个AES密钥。然后,使用encrypt
方法将明文加密为字节数组,并使用Base64编码进行输出。最后,使用decrypt
方法将加密的字节数组解密为原文字符串。
请注意,这只是一个简单的示例,实际使用中可能需要更多的异常处理和安全防护措施。