JAVA中使用AES加密


/*待加密的数据*/
byte[] data = "ABCDEFGHIJKLMNOP".getBytes(Charset.defaultCharset());
/*用来存储加密后的数据*/
byte[] encryptDate = new byte[data.length];
/*密钥*/
byte[] key = "1234567890123456".getBytes(Charset.defaultCharset());
/*初始向量IV*/
byte[] iv = "1234567890123456".getBytes(Charset.defaultCharset());

1.首先是创建一个加密器Cipher:

Cipher encoder = Cipher.getInstance("AES/CBC/NoPadding");

2.创建一个SecretKeySpec密钥对象:

SecretKeySpec keySpec = new SecretKeySpec(key, "AES");

3.创建初始向量IV(CBC模式):

IvParameterSpec ivParam = new IvParameterSpec(iv);

4.初始化加密器:

encoder.init(Cipher.ENCRYPT_MODE, keySpec, ivParam);

5.执行加密:

encryptData = encoder.doFinal(data);

完整代码:

import java.nio.charset.Charset;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

public class AES {
    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        byte[] data = "ABCDEFGHIJKLMNOP".getBytes(Charset.defaultCharset());
        byte[] encryptData = new byte[data.length];
        byte[] key = "1234567890123456".getBytes(Charset.defaultCharset());
        byte[] iv = "1234567890123456".getBytes(Charset.defaultCharset());
        SecretKeySpec keySpec = new SecretKeySpec(key, "AES");
        IvParameterSpec ivParam = new IvParameterSpec(iv);
        try{
            Cipher encoder = Cipher.getInstance("AES/CBC/NoPadding");
            encoder.init(Cipher.ENCRYPT_MODE,keySpec,ivParam);
            encryptData = encoder.doFinal(data);
        }catch(NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException | InvalidAlgorithmParameterException | IllegalBlockSizeException | BadPaddingException e){
            /*do something*/
        } 
    }
}
### Java AES 加密与 MySQL AES 解密的组合实现 #### 1. Java 中的 AES 加密实现 在 Java 中可以通过 `javax.crypto` 提供的功能来实现 AES 加密。为了确保加密后的数据能够在 MySQL 的解密功能中正常工作,需要注意以下几点: - 使用相同的密钥长度(通常为 128 位或 256 位)。 - 设置一致的初始化向量 (IV),因为 MySQL 的内置 AES 函数默认不支持 CBC 模式的 IV 参数[^1]。 以下是基于 ECB 模式的一个简单示例代码片段: ```java import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.util.Base64; public class AESEncryption { private static final String ALGORITHM = "AES/ECB/PKCS5Padding"; private static final String KEY = "key1key1key1key1"; // 密钥需为固定长度 public static String encrypt(String data, String key) throws Exception { Cipher cipher = Cipher.getInstance(ALGORITHM); SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(), "AES"); cipher.init(Cipher.ENCRYPT_MODE, secretKey); byte[] encryptedData = cipher.doFinal(data.getBytes()); return Base64.getEncoder().encodeToString(encryptedData); // 返回Base64编码字符串 } } ``` 注意:由于 MySQL 默认使用的模式是 ECB 而非 CBC[^3],因此建议采用上述方法中的 ECB 模式以保持兼容性。 #### 2. MySQL 中的 AES 解密实现 MySQL 自带了 `AES_DECRYPT()` 和 `AES_ENCRYPT()` 函数用于处理 AES 数据加解密操作。这些函数内部实现了标准的 AES 算法,默认情况下使用的是 ECB 模式,并且不需要显式指定 IV 值[^3]。 下面是一个 SQL 查询语句的例子展示如何调用该数据库端口完成解码过程: ```sql SELECT CAST(AES_DECRYPT('C796C6C418AA82A90FC7C326102CF119', 'key1key1key1key1') AS CHAR); ``` 这里 `'C796C6C418AA82A90FC7C326102CF119'` 是由 Java 应用程序生成并通过某种方式存储到表里的已加密二进制数据;而第二个参数则是匹配之前设定好的相同秘钥[^3]。 #### 3. 关键注意事项 - **密钥管理**: 双方都应严格保管好共享秘密钥匙以防泄露风险。 - **字符集一致性**: 如果涉及中文或其他特殊字符,则要确认客户端和服务端之间存在统一的文字编码设置以免乱码现象发生。 - **性能考量**: 对于大规模批量记录的操作可能会影响效率,尤其是在频繁读取更新场景下更应注意优化策略[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值