AES加密java源码
时间: 2024-06-15 18:00:55 浏览: 158
AES加密是一种常用的对称加密算法,Java中也提供了AES加密的实现。以下是一个简单的AES加密Java源码示例:
```
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
public class AESUtil {
// 生成AES秘钥
public static byte[] initKey() throws Exception {
KeyGenerator kg = KeyGenerator.getInstance("AES");
kg.init(128); // 生成128位的AES秘钥
SecretKey secretKey = kg.generateKey();
return secretKey.getEncoded();
}
// AES加密
public static byte[] encrypt(byte[] data, byte[] key) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
return cipher.doFinal(data);
}
// AES解密
public static byte[] decrypt(byte[] encryptedData, byte[] key) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
return cipher.doFinal(encryptedData);
}
}
```
这段代码实现了AES秘钥的生成、加密和解密功能。其中,`initKey()`方法用于生成128位的AES秘钥,`encrypt()`方法用于对数据进行AES加密,`decrypt()`方法用于对加密后的数据进行解密。在使用时,需要先调用`initKey()`方法生成秘钥,然后使用`encrypt()`方法进行加密,再使用`decrypt()`方法进行解密。
阅读全文