在做一个Android项目的时候,从学校服务器接口返回报文是json格式。接口调用成功后,输出返回的报文中有类似“\u79fb\u52a8\u4e92\u8054\u7f51\u5e94\u7528 ”的Unicode字符,有点纳闷,记得java是会自动转换Unicode字符为中文才对。但是通过检查发现,其中的没一个“\”在java中都有转义符,也就是说其实是有两个“\”的。自然就不会显示中文了。
最开始我是使用replace(“\\”,“\”),但是不行,具体我也不太知道为什么,后面提供的一个连接有作者会说,我个人没有怎么看懂。
后来,通过http://my.oschina.net/u/1010578/blog/366252,这篇文章提供的线索,找到org.apache.commons.lang.StringEscapeUtils这个工具类,这个是commons-lang3包中的一个工具类,google一下又很多介绍方式,我就简单的用了一下,下载-导入到工程-使用,步骤很简单。具体可以参看链接的文章。
上述的工具类可以将字符串中的转义给去掉,之后将Unicode的字符串转化为utf-8编码的文字就很简单了,给的链接也提供了方法,但是感觉比较难,这里给出一个简单的方式。
代码如下:public static String decodeUnicode(String string) {
try {
// Convert from Unicode to UTF-8
byte[] utf8 = string.getBytes("UTF-8");
// Convert from UTF-8 to Unicode
string = new String(utf8, "UTF-8");
} catch (UnsupportedEncodingException e) {
Log.e(MainActivity.TAG, string);
}
return string;
}
链接:http://blog.csdn.net/xyw_blog/article/details/8510740 同时给出了utf8转Unicode的方法
链接:http://my.oschina.net/u/1010578/blog/366252 比较详细的介绍了该问题的解决。