我正在做一个关于使用河豚做加密的任务& java解密。如何解决javax.crypto.IllegalBlockSizeException:数据不是块大小对齐
我已经添加了一个提供程序,并获得实例“Blowfish/ECB/NoPadding”,但是我在执行加密时仍然出现此错误。
Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
例如为:
public static byte[] encrypt(byte to_encrypt[], byte strkey[]) {
try {
SecretKeySpec key = new SecretKeySpec(strkey, "Blowfish");
Cipher cipher = Cipher.getInstance("Blowfish/ECB/NoPadding");
cipher.init(Cipher.ENCRYPT_MODE, key);
return cipher.doFinal(to_encrypt); // <=========== error
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
导致
javax.crypto.IllegalBlockSizeException: data not block size aligned
at org.bouncycastle2.jce.provider.JCEBlockCipher.engineDoFinal(JCEBlockCipher.java:686)
at javax.crypto.Cipher.doFinal(Cipher.java:1171)
谢谢。
使用填充工作给你,你可以请分享固定的代码? – Shivam657 2017-07-25 10:14:38