Java中文乱码的解决办法

33次阅读

共计 743 个字符,预计需要花费 2 分钟才能阅读完成。

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

这是因为 JAVA 中默认的编码方式是 UNICODE,而中国人通常使用的文件和 DB 都是基于 GB2312 或者 BIG5 等编码,故会出现此问题。以前我也经常为这个问题而苦恼,后来经查了些资料,终于解决了,我知道一定有很多朋友也会碰到这个问题,所以特就总结了一下,来拿出来让大家一起分享了。

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”);

就不会出现中文问题了。

正文完
 0