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

首先说明几点:

在文件中任何时候出现utf-8、UTF-8、utf8、UTF8其作用都是一样的。tomcat、resin、mysql可没有我们这么笨。网上许多文章还煞有介事的特别指出其一个个的区别,纯属无稽之谈。

内容来自dedecms

我的软件环境:

中文WINDOWS XP (linux可作相应修改)

Apache Tomcat 5.5.6 Server

phpMyAdmin 2.6.4-pl4

MySQL 5.0.19-nt

内容来自dedecms

按下面步骤修改: 内容来自dedecms

一、在JSP静态文件中正确显示UTF-8:

dedecms.com

1、JSP文件用支持UTF-8的文字编辑器编辑,如EditPlus、UltraEdit,并把原来ascii转换成utf-8(菜单里有)。

copyright dedecms

2、JSP文件头改成:

有无这句无所谓(但在.html文件中是必要的):

本文来自织梦

二、FORM的正确提交: 本文来自织梦

1、getParameter之前加入:

request.setCharacterEncoding("utf-8");

这一步也可以用Filter的办法,参见其它文章。 dedecms.com

2、request时,只需要写成最简单的形式:

String name1= new String(request.getParameter("username"));

String pwd1= new String(request.getParameter("password"));

织梦好,好织梦

三、连接mysql: dedecms.com

1、mysql配置文件:

修改mysql在windows\my.ini里default-character-set=utf-8 dedecms.com

2、mysql里数据库和表也都设为utf8_unicode_ci

dedecms.com

3、数据库连结:jdbc:mysql://localhost/mydb?useUnicode=true&characterEncoding=utf-8

注意,关键就在于此:此句中间是''&''不是''&''在www.Jdon.com的banq和许多牛人的文章中都写成了''&''。这可能是发文章时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" 内容来自dedecms

至此,在页面上显示中文、从数据库读取并显示、插入、修改中文都正常了。

并且由于是utf-8,您可以试一下,在form里同时输入中文、英文、日文、韩文,照样正常显示。 内容来自dedecms

PS:

虽然没有完全测试过,但在我的使用中操作系统、JDK、TOMCAT或resin的编码对此问题没有造成影响。

我测试时resin初始化显示的JDK就是GBK、zh,但没有问题。

另外,.java文件是utf-8还是ascii编码都没有关系,生成的.class一样能用。

经楼下朋友的提醒,我需要补充一下:

1、数据库连结时,在.jsp和.java文件中应该用&号,而XML文件中需要用& 这也是banq的本意。只是我们太菜没能直接领会。

2、在我的测试中,connector-J已经是3.0以上但如果不加useUnicode=true&characterEncoding=utf-8访问数据库还是会有问题。所以建议还是加上。

copyright dedecms

PS2:对用GET提交的中文问题, 内容来自dedecms, $False$

修改tomcat/conf/server.xml

最后加入:URIEncoding=''utf-8'' 织梦好,好织梦

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值