大家好,又见面了,我是你们的朋友全栈君。
在基于JAVA的编程中,经常会碰到汉字显示乱码的问题,经一番查询现总结如下。
在JSP中建议网页编码方式用GBK,这样会方便一些。
这个问题是因为JAVA编码方式转换出现了问题,Java中默认的编码方式是UNICODE,而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码,故会出现此问题。我知道一定有很多朋友也会碰到这个问题,所以特就总结了一下,来拿出来让大家一起分享了。自己也做个备忘。
1、在网页中输出中文。
JAVA在网络传输中使用的编码是”ISO-8859-1″,故在输出时需要进行转化,如:
String str=”中文”;
str=new String(str.getBytes(“GB2312″),”GBK”);
但如果在编译程序时,使用的编码是“GB2312”,且在中文平台上运行此程序,不会出现此问题,一定要注意。
2、从参数中读取中文
这正好与在网页中输出相反如:
str=new String(str.getBytes(“8859_1″),”GBK”);
3、操作DB中的中文问题
一个较简单的方法是:在“控制面扳”中,把“区域”设置为“英语(美国)”。如果还会出现乱码,还可进行如下设置: (网上看的,自己没做过实验)
取中文时:String XSDWMC=new String(prs.getString(“XSDWMC”).getBytes(“GB2312″),”GBK”));
向DB中可直接写入GBK,这里少一次转换
4、在JSP中的中文解决:
在“控制面扳”中,把“区域”设置为“英语(美国)”. (网上看的,自己没做过实验)
在JSP页面中加入:
如果还不行正常显示,则还要进行下面的转换:
如:name=new String(name.getBytes(“ISO-8859-1″),”GBK”);
就不会出现中文乱码问题了。
—————————–
如果以上还不能解决您的问题,请看我转载的一片文章
http://blog.csdn.net/mrliming/archive/2010/01/14/5191199.aspx
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/157097.html原文链接:https://javaforall.cn