AES加密,CBC模式,0填充

本文深入探讨了Java中AES加密算法的CBC模式实现细节,包括NoPadding、PKCS5Padding和PKCS7Padding填充方式的使用。通过具体代码示例,展示了如何处理密钥长度验证、初始化向量设置及数据块大小对齐等问题。

java的aes加密的CBC模式只有NoPadding,PKCS5Padding,PKCS7Padding,因此0填充需要手动更改

public static byte[] encrypt(byte[] data, byte[] iv, byte[] key) {
if(key.length != 16) {
throw new RuntimeException("Invalid AES key length (must be 16 bytes)");
} else {
try {
SecretKeySpec secretKey = new SecretKeySpec(key, "AES");
byte[] enCodeFormat = secretKey.getEncoded();
SecretKeySpec seckey = new SecretKeySpec(enCodeFormat, "AES");
Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
int blockSize=cipher.getBlockSize();
int length=data.length;
if(length%blockSize!=0){
length=length+(blockSize-(length%blockSize));
}
byte[] plaintext=new byte[length];
System.arraycopy(data,0,plaintext,0,data.length);
IvParameterSpec ivSpec = new IvParameterSpec(iv);
cipher.init(1, seckey, ivSpec);
byte[] result = cipher.doFinal(plaintext);
return result;
} catch (Exception var9) {
throw new RuntimeException("encrypt fail!", var9);
}
}
}

转载于:https://www.cnblogs.com/jakin3130/p/10755040.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值