春天的熊

Java:byte[]->Base64 String-> byte[]

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

用传统的:

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

将出现乱码:

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

所以转化为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.         } 

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

 

本文出自 “乔磊的博客 学习 进步” 博客,请务必保留此出处http://sucre.blog.51cto.com/1084905/531923

2012-03-08
/  标签: Javabase64
   
评论
坚信上帝的延迟,并不是上帝的拒绝。

那些还没有到来的,总会在找寻和尝试中来到。

Here,成长的角落。

Q_Q:317886534