请教高手:new String(byte).getBytes() 与 byte.clone() 得到的Byte有啥区别

在做加密解密时发现
将加密后的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;所以不把加密之后的二进制串当正常字符串看待,把它们当成整数来处理的话不会丢失信息

byte在java的有效范围是-128~127。不会打印出200和222的。
针对200和222,会打出-56和-34.
但是,字符串转码得到-17和-65,应该跟字符集有关。