java中String的getBytes方法使用
public class test { public static void main(String[] args){ String a="哈哈"; try { byte[] aa = a.getBytes("GB2312"); byte[] ab = a.getBytes("UTF-8"); for (int i = 0; i < aa.length; i++) { System.out.print(aa[i]); } System.out.println(); for (int i = 0; i < ab.length; i++) { System.out.print(ab[i]); } System.out.println(); System.out.println(new String(aa)); System.out.println(new String(ab, "UTF-8")); System.out.println(new String(aa, "UTF-8")); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
运行一下例子,你会发现,结果是:
-71-2-71-2
-27-109-120-27-109-120
哈哈
哈哈
????
由此看来,如果要是遇见这种需求的话,从什么转到什么不重要。关键是网络的那一头给你发什么,你这边就用什么方式去接收。
比如,一个String,不管它原来是什么编码,你在网络上传的时候,首先把它.getBytes(mode)转成数组,那么,网络的另一头,你接收到的数据流转成byte[]数组后,要new String(byte[],mode)。不用管它在路上怎么个编码方式。
所以说,只要两边一致。网络socket传输就不会出现乱码。
转自:http://blog.sina.com.cn/s/blog_656088090100go8e.html
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: 微博第三方登录
- 下一篇: phpQuery的用法