Java通信过程的中文乱码的解决

J在基于Java的编程中,常常会碰到汉字的处里及显示的问题。比方一大堆乱码或问号。

这是由于JAVA中默认的编码方式是UNICODE。而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码,故会出现此问题。

假设文件一打开就乱码,能够通过改动软件的编码或者改动文件的编码就能够认为这个问题。

而若是在java的通信中。或者数据库操作之类的其它软件进程通信时,就easy产生乱码。

1、在网页中输出中文。

JAVA在网络传输中使用的编码是”ISO-8859-1”,故在输出时须要进行转化,如:

String str="中文"; 
str=new String(str.getBytes("GB2312"),"8859_1"); 

但假如在编译程序时,使用的编码是“GB2312”,且在中文平台上执行此程序。不会出现此问题。一定要注重。

2、从參数中读取中文

这正好与在网页中输出相反如:

str=new String(str.getBytes("8859_1"),"GB2312");

3、操作DB中的中文问题

一个较简单的方法是:在“控制面扳”中,把“区域”设置为“英语(美国)”。假如还会出现乱码,还可进行例如以下设置:
取中文时:str=new String(str.getBytes("GB2312"));
向DB中输入中文:str=new String(str.getBytes("ISO-8859-1"));

4、在jsp中的中文解决:

在“控制面扳”中,把“区域”设置为“英语(美国)”.
在JSP页面中增加:
假如还不行正常显示。则还要进行以下的转换:
如:name=new String(name.getBytes("ISO-8859-1"),"GBK");
就不会出现中文问题了。

posted @ 2018-04-23 19:17  zhchoutai  阅读(265)  评论(0编辑  收藏  举报