问题描述
在做加密解密时发现将加密后的Byte转成String后再转回Byte 不能正常解密抛出 javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher直接用原加密Byte解密或者Byte.clone()解密正常有谁遇见过这种问题吗是什么原因
解决方案
字符串加密之后得到的二进制串通常意义上已经不是正常的字符串了,如果再编码成字符串的话会丢失信息,举个例子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]); }}}结果按理说应该打印出来200和222,但是结果打印出来是-17和-65;所以不把加密之后的二进制串当正常字符串看待,把它们当成整数来处理的话不会丢失信息
解决方案二:
byte在java的有效范围是-128~127。不会打印出200和222的。针对200和222,会打出-56和-34.但是,字符串转码得到-17和-65,应该跟字符集有关。