Java:byte[]->Base64 String-> byte[]
在加解密程序中,为了使加解密传递的参数使用 String 。就必须将 byte[]( 加密 )->String( 中间传递 )-> byte[]( 解密 ) 。 用传统的: retData = new String(myEncryptedData,); byte [] myData = retData .getBytes(charset); 将出现乱码: String 的 getBytes() 方法是得到一个字串的字节数组,这是众所周知的。但特别要注意的是,本方法将返回该操作系统默认的编码格式的字节数 组。如果你在使用这个方法时不考虑到这一点,你会发现在一个平台上运行良好的系统,放到另外一台机器后会产生意想不到的问题。 所以转化为 String 时,用 Base64 编码。 String str = "2b421331c747d1ec54fa5df39f0a3372" ; // 待加密数据 // 2.1 >>> 调用加密方法 byte [] encryptedData = encrypt(rawKeyData, str); //加密转换 BASE64Encoder enc = new BASE64Encoder(); //加密运算之后 将byte[]转化为base64的String String encryptedtext = enc.encode(encryptedData);