cryptojs.aesPkcs7 java应该使用哪种填充
时间: 2023-07-20 13:27:51 浏览: 98
对于Java应用程序,建议使用PKCS7填充模式(也称为PKCS#5填充模式),因为它是Java加密标准(JCE)的默认填充模式。可以使用Java Cryptography Extension(JCE)提供的javax.crypto.Cipher类来执行AES加密和解密操作。
以下是使用PKCS7填充模式进行AES加密的Java代码示例:
```java
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;
public class AesEncryption {
public static String encrypt(String message, String key) throws Exception {
byte[] keyBytes = key.getBytes("UTF-8");
SecretKeySpec secretKeySpec = new SecretKeySpec(keyBytes, "AES");
byte[] ivBytes = new byte[16];
IvParameterSpec ivParameterSpec = new IvParameterSpec(ivBytes);
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);
byte[] encryptedBytes = cipher.doFinal(message.getBytes("UTF-8"));
return Base64.encodeBase64String(encryptedBytes);
}
}
```
在上面的代码中,我们使用了“AES/CBC/PKCS5Padding”作为加密算法名称来指定使用PKCS7填充模式。请注意,PKCS5Padding和PKCS7Padding实际上是相同的,只是块大小不同而已。因此,使用PKCS5Padding填充模式也是可以的。
阅读全文