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

和自甴很熟 提交于 2021-01-05 02:41:01

在加解密程序中,为了使加解密传递的参数使用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.         } 

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

 

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

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!