Java AES:没有已安装的提供程序支持此密钥:javax.crypto.spec.SecretKeySpec
我正在尝试设置128位AES加密,并且我的Cipher.init上抛出了一个异常:
No installed provider supports this key: javax.crypto.spec.SecretKeySpec
我使用以下代码在客户端生成密钥:
private KeyGenerator kgen;
try {
kgen = KeyGenerator.getInstance("AES");
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
kgen.init(128);
}
SecretKey skey = kgen.generateKey();
然后,此密钥作为标头传递到服务器。它是使用此功能编码的Base64:
public String secretKeyToString(SecretKey s) {
Base64 b64 = new Base64();
byte[] bytes = b64.encodeBase64(s.getEncoded());
return new String(bytes);
}
服务器拉取标头,并执行
protected static byte[] encrypt(byte[] data, String base64encodedKey) throws InvalidKeyException, IllegalBlockSizeException, BadPaddingException {
Cipher cipher;
try {
cipher = Cipher.getInstance("AES");
} catch (NoSuchAlgorithmException ex) {
//log error
} catch (NoSuchPaddingException ex) {
//log error
}
SecretKey key = b64EncodedStringToSecretKey(base64encodedKey);
cipher.init(Cipher.ENCRYPT_MODE, key); //THIS IS WHERE IT FAILS
data = cipher.doFinal(data);
return data;
}
private static SecretKey b64EncodedStringToSecretKey(String base64encodedKey) {
SecretKey key = null;
try {
byte[] temp = Base64.decodeBase64(base64encodedKey.getBytes());
key = new SecretKeySpec(temp, SYMMETRIC_ALGORITHM);
} catch (Exception e) {
// Do nothing
}
return key;
}
为了对此进行调试,我在客户端的密钥生成之后以及服务器端的 cipher.init 之前放置了断点。根据Netbeans的说法,组成SecretKeys的字节是相同的,长度为16个字节(事实上,据我所知,对象是相同的)。
我知道JCE的无限强度,但我的印象不是我需要它来128位AES。
客户端:java 版本“1.6.0_26”
服务器端:java 版本“1.6.0_20”
有什么想法吗?