aes 算法 java_Java使用AES算法

Java中使用AES(CBC,128位)算法加解密。一般加密后都是用一定编码格式进行传输,此处使用Base64算法进行编解码。实现及测试代码如下:

AESUtil.java

package gj.secure;

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.IvParameterSpec;

import javax.crypto.spec.SecretKeySpec;

import java.security.Key;

import java.security.spec.AlgorithmParameterSpec;

import java.util.Base64;

public class AESUtil {

private static final String CIPHER_ALGORITHM_CBC = "AES/CBC/PKCS5Padding";

private static final String KEY_ALGORITHM = "AES";

public static byte[] initKey() throws Exception {

KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);

kg.init(128);

SecretKey secretKey = kg.generateKey();

return secretKey.getEncoded();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AES算法Java实现可以通过Java的加密库javax.crypto来实现。具体步骤如下: 1. 导入相应的包,引入javax.crypto.Cipher和javax.crypto.spec.SecretKeySpec类。 2. 创建一个Cipher对象,指定使用AES算法。 3. 创建一个SecretKeySpec对象,将密钥以字节数组的形式传递给它。 4. 使用Cipher对象的init()方法初始化加密/解密模式和密钥。 5. 调用Cipher对象的doFinal()方法,传入要加密/解密的数据。 6. 处理加密/解密后的数据。 以下是一个简单的AES加密和解密的示例代码: ```java import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; public class AESExample { private static final String key = "0123456789abcdef"; // 密钥,必须为16字节长度的字符串 public static byte[] encrypt(byte[] data) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec); return cipher.doFinal(data); } public static byte[] decrypt(byte[] encryptedData) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.DECRYPT_MODE, secretKeySpec); return cipher.doFinal(encryptedData); } public static void main(String[] args) throws Exception { String text = "搞事情"; byte[] encryptedData = encrypt(text.getBytes()); String base64EncryptedData = new String(java.util.Base64.getEncoder().encode(encryptedData)); System.out.println("AES加密后:" + base64EncryptedData); byte[] decryptedData = decrypt(java.util.Base64.getDecoder().decode(base64EncryptedData)); String decryptedText = new String(decryptedData); System.out.println("AES解密后:" + decryptedText); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值