使用Java实现AES算法
时间: 2024-05-11 20:08:48 浏览: 91
以下是Java实现AES算法的示例代码:
```java
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
public class AESUtil {
private static final String ALGORITHM = "AES";
private static final String TRANSFORMATION = "AES/ECB/PKCS5Padding";
/**
* 加密方法
*
* @param plainText 明文
* @param key 密钥
* @return 密文
* @throws Exception 异常
*/
public static String encrypt(String plainText, String key) throws Exception {
SecretKeySpec keySpec = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), ALGORITHM);
Cipher cipher = Cipher.getInstance(TRANSFORMATION);
cipher.init(Cipher.ENCRYPT_MODE, keySpec);
byte[] encryptedBytes = cipher.doFinal(plainText.getBytes(StandardCharsets.UTF_8));
return Base64.getEncoder().encodeToString(encryptedBytes);
}
/**
* 解密方法
*
* @param cipherText 密文
* @param key 密钥
* @return 明文
* @throws Exception 异常
*/
public static String decrypt(String cipherText, String key) throws Exception {
SecretKeySpec keySpec = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), ALGORITHM);
Cipher cipher = Cipher.getInstance(TRANSFORMATION);
cipher.init(Cipher.DECRYPT_MODE, keySpec);
byte[] encryptedBytes = Base64.getDecoder().decode(cipherText);
byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
return new String(decryptedBytes, StandardCharsets.UTF_8);
}
}
```
示例代码中的 `encrypt` 方法接受明文和密钥,使用AES算法进行加密,并返回Base64编码的密文;`decrypt` 方法接受密文和密钥,使用AES算法进行解密,并返回明文。请注意,此示例代码使用AES/ECB/PKCS5Padding模式进行加解密,这不是最安全的模式,建议根据实际需求选择更安全的模式。
阅读全文
相关推荐

















