java 生成 aes 加密
时间: 2023-06-22 15:35:03 浏览: 108
以下是Java生成AES加密的示例代码:
```java
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Base64;
public class AESUtil {
// 生成AES密钥
public static byte[] generateKey() throws NoSuchAlgorithmException {
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
keyGenerator.init(128, new SecureRandom());
SecretKey secretKey = keyGenerator.generateKey();
return secretKey.getEncoded();
}
// AES加密
public static String encrypt(String data, byte[] key) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
byte[] encryptedData = cipher.doFinal(data.getBytes());
return Base64.getEncoder().encodeToString(encryptedData);
}
// AES解密
public static String decrypt(String encryptedData, byte[] key) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
byte[] data = Base64.getDecoder().decode(encryptedData);
byte[] decryptedData = cipher.doFinal(data);
return new String(decryptedData);
}
public static void main(String[] args) throws Exception {
byte[] key = generateKey();
System.out.println("AES Key: " + Base64.getEncoder().encodeToString(key));
String data = "Hello, world!";
System.out.println("Original Data: " + data);
String encryptedData = encrypt(data, key);
System.out.println("Encrypted Data: " + encryptedData);
String decryptedData = decrypt(encryptedData, key);
System.out.println("Decrypted Data: " + decryptedData);
}
}
```
首先,我们使用`KeyGenerator`类生成128位的AES密钥,然后使用`SecretKeySpec`类将密钥转换成`SecretKey`对象。
然后,我们使用`Cipher`类来执行加密和解密操作。在本例中,我们使用ECB模式和PKCS5Padding填充模式。加密后的数据使用Base64编码,以便在网络上传输。
最后,我们可以使用`generateKey()`方法生成一个新的密钥,然后使用`encrypt()`方法加密数据,使用`decrypt()`方法解密数据。
阅读全文