jdk8环境正常,在切换到jdk11时,抛出异常
java.security.InvalidKeyException: Wrong algorithm: AES or Rijndael required
大致意思是算法错误,需要AES算法或一个叫Rijndael的算法
没改之前的代码是这样的
/*
* Copyright 2020 DuJiang.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.jt.saas.ams.utils;
import org.apache.commons.codec.binary.Base64;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.Charset;
import java.security.Security;
import java.util.UUID;
/**
* AESUtils
*
* @author DuJiang
*/
public final class AESUtils {
private static final String ALGORITHM = "CBC";
private static final String AES_CBC_PKCS7Padding = "AES/CBC/PKCS5Padding";
public static final String aesKey = "";
public static final String aesIv = "";
static {
Security.addProvider(new BouncyCastleProvider());
}
/**
* 加密
*
* @param encryptText 需要加密的信息
* @param key 密钥字符串
* @param iv 向量
* @param charset 字符集名称
* @return String 加密后Base64编码的字符串
*/
public static final String encrypt(final String encryptText, final String key, final String iv, final String charset) {
try {
Cipher cipher = Cipher.getInstance(AES_CBC_PKCS7Padding);
SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM);
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes(charset));
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);
return Base64.encodeBase64String(cipher.doFinal(encryptText.getBytes(Charset.forName(charset))));
} catch (Exception e) {
e.printStackTrace();
}
return encryptText;
}
/**
* 解密
*
* @param decryptText 需要解密的信息
* @param key 密钥字符串
* @param iv 向量
* @return String 解密后的字符串
*/
public static final String decrypt(final String decryptText, final String key, final String iv) {
return decrypt(decryptText, key, iv, "UTF-8");
}
/**
* 解密
*
* @param decryptText 需要解密的信息
* @param key 密钥字符串
* @param iv 向量
* @param charset 字符集名称
* @return String 解密后的字符串
*/
public static final String decrypt(final String decryptText, final String key, final String iv, final String charset) {
try {
Cipher cipher = Cipher.getInstance(AES_CBC_PKCS7Padding);
SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM);
IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes(charset));
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec);
return new String(cipher.doFinal(Base64.decodeBase64(decryptText)), Charset.forName(charset));
} catch (Exception e) {
e.printStackTrace();
}
return decryptText;
}
public static void main(String[] args) {
String aa = "yanfa07"; //ErRJ7PoJBjN3fVdVu/iUkA== 35FOnbzkZRKAsVCr8iDOhA==
String encrypt = AESUtils.encrypt(aa, AESUtils.aesKey, AESUtils.aesIv, "UTF-8");
System.out.println(encrypt);
System.out.println(AESUtils.decrypt("35FOnbzkZRKAsVCr8iDOhA==", AESUtils.aesKey, AESUtils.aesIv, "UTF-8"));
System.out.println(UUID.randomUUID().toString());
}
}
后面把这里的换成AES成功解决
private static final String ALGORITHM = "AES";