中文乱码、jsp操作数据库中文乱码!帮你解决!!!

                                    中文乱码、jsp操作数据库中文乱码!

 

      在基于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");

  就不会出现中文问题了。

 

5.消除纯HTML页和JSP页在Tomcat环境下运行的乱码

这个是由于流览器无法选择编码方式造成的,   手动从IE中选择“GB2312”即可解决;也可以网页中加入META标记或Page指令;
META标记如下:
<meta   http-equiv= "Content-Type "   content= "text/html;   ch***t=GB2312 ">
Page指令如下:
<%@   page   language= "java "   contentType= "text/html;   ch***t=GB2312 "   pageEncoding= "GB2312 "%>

 

JSP获取页面参数时一般采用系统默认的编码方式,如果页面参数的编码类型和系统默认的编码类型不一致,很可能就会出现乱码。解决这类乱码问题的基本方法是在页面获取参数之前,强制指定request获取参数的编码方式:request.setCharacterEncoding("GBK")或request.setCharacterEncoding("gb2312")。

如果在JSP将变量输出到页面时出现了乱码,可以通过设置response.setContentType("text/html;charset=GBK")或response.setContentType("text/html;charset=gb2312")解决。

 

 

6.一般jdbc驱动连接时要注意:
String   url   = "jdbc:mysql://localhost/BookStore?useUnicode=true&characterEncoding=gb2312 ";
conn=DriverManager.getConnection(url, "root ", " ");

一般情况下用   String   url   = "jdbc:mysql://localhost/BookStore "应该就能正常显示中文。
总结:修改MySQL   Server数据库默认字符集为“GB2312”,从MySQL读出中文可正常显示;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值