java.security.key jar_AES加密异常java.security.InvalidKeyException: Illegal key size 的解决方法...

package com.ehomepay.merchant.utils;

import java.security.InvalidKeyException;

import java.security.Key;

import java.security.NoSuchAlgorithmException;

import java.security.NoSuchProviderException;

import java.security.Security;

import java.util.Objects;

import java.util.Optional;

import javax.crypto.BadPaddingException;

import javax.crypto.Cipher;

import javax.crypto.IllegalBlockSizeException;

import javax.crypto.KeyGenerator;

import javax.crypto.NoSuchPaddingException;

import javax.crypto.SecretKey;

import javax.crypto.spec.SecretKeySpec;

import org.apache.commons.codec.binary.Base64;

import org.bouncycastle.jce.provider.BouncyCastleProvider;

/**

* @date 2017/12/22

* comments AES加密工具类

*/

public class AESEncryptUtil {

/**

* 加密算法

*/

public static final String KEY_ALGORITHM = "AES";

public enum AES_KEY_SIZE {

/**

* 秘钥长度为128

*/

KEY_LENGTH_128(128),

/**

* 密钥长度为192

*/

KEY_LENGTH_192(192),

/**

* 秘钥长度为256

*/

KEY_LENGTH_256(256);

AES_KEY_SIZE(final int size) {

this.keyLength = size;

}

private final int keyLength;

public int getKeyLength() {

return this.keyLength;

}

}

/**

* 加密算法,分组模式,填充模式

*/

public static final String CIPHER_ALGORITHM = "AES/ECB/PKCS7Padding";

public static byte[] generKey() {

return generKey(AES_KEY_SIZE.KEY_LENGTH_256);

}

public static byte[] generKey(final AES_KEY_SIZE keySize) {

try {

KeyGenerator kgen = KeyGenerator.getInstance(KEY_ALGORITHM);

AES_KEY_SIZE aesKeySize = Optional.ofNullable(keySize).orElse(AES_KEY_SIZE.KEY_LENGTH_128);

kgen.init(aesKeySize.getKeyLength());

SecretKey secretKey = kgen.generateKey();

return secretKey.getEncoded();

} catch (NoSuchAlgorithmException e) {

throw new RuntimeException(e);

}

}

public static String generKeyToBase64(final AES_KEY_SIZE keySize) {

return Base64.encodeBase64String(generKey(keySize));

}

public static String generKeyToBase64() {

return Base64.encodeBase64String(generKey());

}

protected static Key toKey(final byte[] key) {

return new SecretKeySpec(key, KEY_ALGORITHM);

}

protected static Key toKey(final String pwd) {

byte[] key = Base64.decodeBase64(pwd);

return toKey(key);

}

/**

* @param content 明文数据

* @param pwd Base64编码的密钥

* @return 加密数据

*/

public static byte[] encrypt(final byte[] content, final String pwd) {

return encryptService(content, pwd, Cipher.ENCRYPT_MODE);

}

/**

* @param content 明文数据

* @param pwd Base64编码的密钥

* @return 加密数据

*/

public static byte[] encrypt(final byte[] content, final byte[] pwd) {

return encryptService(content, pwd, Cipher.ENCRYPT_MODE);

}

/**

* @param content 密文数据

* @param pwd Base64编码的密钥

* @return 明文数据

*/

public static byte[] decrypt(final byte[] content, final String pwd) {

return encryptService(content, pwd, Cipher.DECRYPT_MODE);

}

/**

* @param content 密文数据

* @param pwd Base64编码的密钥

* @return 明文数据

*/

public static byte[] decrypt(final byte[] content, final byte[] pwd) {

return encryptService(content, pwd, Cipher.DECRYPT_MODE);

}

private static byte[] encryptService(final byte[] content, final byte[] pwd, int model) {

Objects.requireNonNull(content, "明文数据不能为空");

Objects.requireNonNull(pwd, "密钥信息不能为空");

try {

initBC();

Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM, "BC");

cipher.init(model, toKey(pwd));

return cipher.doFinal(content);

} catch (NoSuchAlgorithmException | NoSuchProviderException | NoSuchPaddingException | InvalidKeyException

| IllegalBlockSizeException | BadPaddingException e) {

throw new RuntimeException(e);

}

}

private static byte[] encryptService(final byte[] content, final String pwd, int model) {

Objects.requireNonNull(content, "明文数据不能为空");

Objects.requireNonNull(pwd, "密钥信息不能为空");

try {

initBC();

Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM, "BC");

cipher.init(model, toKey(pwd));

return cipher.doFinal(content);

} catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidKeyException

| IllegalBlockSizeException | BadPaddingException | NoSuchProviderException e) {

throw new RuntimeException(e);

}

}

private static void initBC() {

Security.addProvider(new BouncyCastleProvider());

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
除了jar包之外,导致java.security.InvalidKeyException: Illegal key size异常的其他原因可能包括以下几点: 1. 未正确安装或配置Java JRE或JDK:在某些情况下,如果Java环境未正确安装或配置,可能导致加密算法无法正常运行,从而引发此异常。此时,需要重新安装或配置Java环境。 2. Java Unlimited Strength Jurisdiction Policy文件缺失或配置问题:某些加密算法需要Java Unlimited Strength Jurisdiction Policy文件的支持才能正常工作。如果缺少该文件,或者文件未正确配置,就会导致Illegal key size异常解决办法是下载并正确配置Java Unlimited Strength Jurisdiction Policy文件。 3. Java的加密算法策略限制:某些情况下,默认的Java加密算法策略可能对加密密钥的长度有限制,当使用的密钥长度超出限制时,就会发生Illegal key size异常解决办法是通过手动修改Java加密算法策略文件,将密钥长度限制调高。 4. 使用的加密算法不支持所提供的密钥长度:有些加密算法只支持特定长度的密钥。如果使用的加密算法不支持所提供的密钥长度,就会触发Illegal key size异常解决方法是选择合适长度的密钥,或者尝试使用其他支持所需密钥长度的加密算法。 总结起来,导致java.security.InvalidKeyException: Illegal key size异常的除了jar包之外的其他原因可能是Java环境未正确安装或配置、缺少Java Unlimited Strength Jurisdiction Policy文件、加密算法策略限制或使用不支持所提供的密钥长度的加密算法。需要检查和解决这些问题才能解决异常

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值