在做加密解密时发现
将加密后的Byte转成String后再转回Byte 不能正常解密
抛出 javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher
直接用原加密Byte解密或者Byte.clone()解密正常
有谁遇见过这种问题吗
是什么原因
在做加密解密时发现
将加密后的Byte转成String后再转回Byte 不能正常解密
抛出 javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher
直接用原加密Byte解密或者Byte.clone()解密正常
有谁遇见过这种问题吗
是什么原因
字符串加密之后得到的二进制串通常意义上已经不是正常的字符串了,如果再编码成字符串的话会丢失信息,举个例子
[code="java"]
public class Main {
public static void main(String[] args)throws Exception {
byte[] bytes={(byte)200,(byte)222};
String s = new String(bytes);#丢失信息
System.out.println(s);
byte[] b=s.getBytes();
for(int i=0;i<2;i++){
System.out.println(b[i]);
}
}
}
[/code]
结果按理说应该打印出来200和222,但是结果打印出来是-17和-65;所以不把加密之后的二进制串当正常字符串看待,把它们当成整数来处理的话不会丢失信息