在加解密程序中,为了使加解密传递的参数使用String。就必须将 byte[](加密)->String(中间传递)-> byte[](解密)

用传统的:

 
  
  1. retData = new String(myEncryptedData,);  
  2. byte[] myData = retData.getBytes(charset); 

将出现乱码:

StringgetBytes()方法是得到一个字串的字节数组,这是众所周知的。但特别要注意的是,本方法将返回该操作系统默认的编码格式的字节数 组。如果你在使用这个方法时不考虑到这一点,你会发现在一个平台上运行良好的系统,放到另外一台机器后会产生意想不到的问题。 

所以转化为String时,用Base64编码。 

 
  
  1. String str = "2b421331c747d1ec54fa5df39f0a3372"// 待加密数据  
  2.         // 2.1 >>> 调用加密方法  
  3.         byte[] encryptedData = encrypt(rawKeyData, str);  
  4.         //加密转换  
  5.         BASE64Encoder enc = new BASE64Encoder();  
  6.         //加密运算之后 将byte[]转化为base64的String  
  7.         String encryptedtext = enc.encode(encryptedData);  
  8.         // 解密运算 将base64的String转化为byte[]  
  9.         BASE64Decoder dec = new BASE64Decoder();  
  10.         try {  
  11.             encryptedData = dec.decodeBuffer(encryptedtext);  
  12.         } catch (IOException e) {  
  13.             e.printStackTrace();  
  14.         } 

这样转换后的字符串就正确了。