欢迎来到HugNew-拥抱变化,扫一扫右边二维码关注微信订阅号:Martin说 或 加QQ群:427697041互相交流,Stay hungry, Stay foolish.

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

J2SE Martin 2375℃ 1评论

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

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

转载请注明:HugNew » Java:byte[]->Base64 String-> byte[]

喜欢 (0)or分享 (0)
发表我的评论
取消评论

表情
(1)个小伙伴在吐槽
  1. Reading this makes my deocsiins easier than taking candy from a baby.
    匿名2015-06-09 03:34 回复