MariaDB社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 5342|回复: 1
打印 上一主题 下一主题

用UTF-8完全解决JSP+MYSQL多国语言文字编码问题

[复制链接]
跳转到指定楼层
1#
发表于 2008-7-16 12:13:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
此问题这是本人经过数天努力,查遍网上所有此类文章最后自己解决的。转载请务必注明出处:
http://blog.donews.com/ralix/

首先说明几点:
在文件中任何时候出现utf-8、UTF-8、utf8、UTF8其作用都是一样的。tomcat、resin、mysql可没有我们这么笨。网上许多文章还煞有介事的特别指出其一个个的区别,纯属无稽之谈。
我的软件环境:
中文WINDOWS XP (linux可作相应修改)
Apache Tomcat 5.5.6 Server
phpMyAdmin 2.6.4-pl4
MySQL 5.0.19-nt
按下面步骤修改:
一、在JSP静态文件中正确显示UTF-8:
1、JSP文件用支持UTF-8的文字编辑器编辑,如EditPlus、UltraEdit,并把原来ascii转换成utf-8(菜单里有)。
2、JSP文件头改成:
<%@ page c language="java"  import="java.sql.*"%>
有无这句无所谓(但在.html文件中是必要的):
<head>
<meta http-equiv="content-type" c />
</head>
二、FORM的正确提交:
1、getParameter之前加入:
request.setCharacterEncoding("utf-8");
这一步也可以用Filter的办法,参见其它文章。
2、request时,只需要写成最简单的形式:
String name1= new String(request.getParameter("username"));
String pwd1= new String(request.getParameter("password"));
三、连接mysql:
1、mysql配置文件:
修改mysql在windows\my.ini里default-character-set=utf-8
2、mysql里数据库和表也都设为utf8_unicode_ci
3、数据库连结:jdbc:mysql://localhost/mydb?useUnicode=true&characterEncoding=utf-8
注意,关键就在于此:此句中间是'&'不是'&amp;'在www.Jdon.com的banq和许多牛人的文章中都写成了'&amp;'。这可能是发文章时html自动转化的。但这的确给我们带来了很大的麻烦。会产生如下错误或问号:
java.sql.SQLException: Syntax error or access violation, message from server: "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''asdf' at line 1"

至此,在页面上显示中文、从数据库读取并显示、插入、修改中文都正常了。
并且由于是utf-8,您可以试一下,在form里同时输入中文、英文、日文、韩文,照样正常显示。
PS:
虽然没有完全测试过,但在我的使用中操作系统、JDK、TOMCAT或resin的编码对此问题没有造成影响。
我测试时resin初始化显示的JDK就是GBK、zh,但没有问题。
另外,.java文件是utf-8还是ascii编码都没有关系,生成的.class一样能用。

经楼下朋友的提醒,我需要补充一下:
1、数据库连结时,在.jsp和.java文件中应该用&号,而XML文件中需要用&amp; 这也是banq的本意。只是我们太菜没能直接领会。
2、在我的测试中,connector-J已经是3.0以上但如果不加useUnicode=true&characterEncoding=utf-8访问数据库还是会有问题。所以建议还是加上。
PS2:
对用GET提交的中文问题,修改tomcat/conf/server.xml
<Connector acceptCount='100' connectionTimeout='20000'  .../>最后加入:URIEncoding='utf-8'

PS3:
最近发现MYSQL在windows/my.ini里,必须写成utf8,这是与mysql/share/charsets里的编码相对应的。


大功告成,语言大统。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖 顶 踩
2#
发表于 2010-4-30 13:57:10 | 只看该作者
我为字符集的问题吃了无休止的苦头,无内
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|MariaDB社区 ( 京ICP备07012489号    |
业务联系: QQ:48474881; 邮箱: 48474881@qq.com; 电话:13911732319
声明:本站部分文章是网友转载,若未经作者同意或署名有误,请联系网站管理员。

GMT+8, 2024-11-25 07:55 , Processed in 0.104118 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表