unicode转换成gbk或者中文

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_26819733/article/details/49743199
<span style="white-space:pre">	</span>public static String convert(String utfString){
		StringBuilder sb = new StringBuilder();
		int i = -1;
		int pos = 0;
		
		while((i=utfString.indexOf("\\u", pos)) != -1){
			sb.append(utfString.substring(pos, i));
			if(i+5 < utfString.length()){
				pos = i+6;
				sb.append((char)Integer.parseInt(utfString.substring(i+2, i+6), 16));
			}
			//System.out.println(i+" "+pos+" "+utfString.length());
			if(pos+6>utfString.length()){
				sb.append(utfString.substring(pos,utfString.length()));
			}
		}
		//System.out.println(utfString.substring(utfString.length()-3,utfString.length())+"len");
		
		return sb.toString();
	}

这是我做项目遇到一个问题,就是服务器传来了json数据,但是出来的中文是这种\u5C0F\u8F89\u8F89 unicode格式的,于是我去百度,找到这段简短的代码,其他都好长,我用的时候,的确能成功转换,但是有个bug就是json结束的括号那些没了,于是我改了改代码,转换全部成功了,你也可以试试哦,代码哪里找到的我也忘了,作者请见谅啊


17.11.20更新后面找到了API,如下:

import org.apache.commons.lang3.StringEscapeUtils;

public class Test {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String unicod = StringEscapeUtils.escapeJava("测试");
		String code = StringEscapeUtils.unescapeJava(unicod);
		
		System.out.println("unicode:"+unicod+"\tcode:"+code);
	}

}

            
阅读更多

没有更多推荐了,返回首页