在加解密程序中,为了使加解密传递的参数使用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);
- // 解密运算 将base64的String转化为byte[]
- BASE64Decoder dec = new BASE64Decoder();
- try {
- encryptedData = dec.decodeBuffer(encryptedtext);
- } catch (IOException e) {
- e.printStackTrace();
- }
这样转换后的字符串就正确了。
本文出自 “乔磊的博客 学习 进步” 博客,请务必保留此出处http://sucre.blog.51cto.com/1084905/531923
来源:oschina
链接:https://my.oschina.net/u/79159/blog/296401