方法三
1>本文将消除乱码分为三步:
>消除页面乱码,
>消除从mysql教程中读出中文乱码,
>消除插入mysql数据库教程中的中文乱码;
15>注意编码表示方式在网页特效p/jsp.html target=_blank >jsp教程与mysql中的区别,如下:
jsp: gb2312, gbk, utf-8....
mysql: gb2312, gbk, utf8....
关键问题:编码,建议统一为gb2312或gbk,本文使用gb2312,gbk未测试;
【step1】: 消除纯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"%>
前面说明中已经提到, meta在2k下可能不起作用(xp下时了时坏),因为简单起见,加入page指令似乎是一个一劳永逸的事情;
总结: 加入page指令,一定可以使纯jsp页面或html页面在tomcat环境下正常显示。
【step2】: 消除从mysql数据库中读出中文的乱码
分为两个目标: step1: 从mysql客户端查看中文正常, step2: 从网页中查看中文正常;
1: 在用sql脚本创建数据库前,设置mysql的默认编码方式为“gb2312”,
此步可以在mysql-administrator-1.1.0-rc-win.msi中完成,或者是mysql server向导;
这样设置完毕后再用sql 脚本创建数据库, 注意如果sql脚本中有设置字符集为latin1或utf-8的语句,一定要删除。
已发现目前版本《在线书店》中的sql脚本中带有设置默认字符集为latin1,一定要删除!
创建数据库完毕后,用mysql cc或mysql admin可检查所创建的数据库的字符集,如果正确,则用mysql cc或mysql admin都可以正常查看中文;
2: 一般情况下,到这一步,在网页中已经基本能正常显示中文了,但凡事总有例外,可以在数据库连接串处再特别说明一下:
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读出中文可正常显示;
例外: 此时仍有可能还有乱码,如本书光盘中的《在线书店》,请参见前面的说明。
【step3】: 消除插入mysql数据库中的中文乱码
此步比较简单,在jsp页面中加入如下代码:
request.setcharacterencoding("gb2312");