`

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

阅读更多

http://blog.csdn.net/shangpusp/archive/2009/04/06/4052943.aspx

 

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

转载出处: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 contentType="text/html; charset=UTF-8" language="java"  import="java.sql.*"%>
有无这句无所谓(但在.html文件中是必要的):
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />
</head>

二、FORM的正确提交:

1、getParameter之前加入:
request.setCharacterEncoding("utf-8");//我的错误在这里,写成response了...呵呵..晕死
这一步也可以用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
 而XML文件中需要用jdbc:mysql://localhost/mydb?useUnicode=true&ampcharacterEncoding=utf-8


至此,在页面上显示中文、从数据库读取并显示、插入、修改中文都正常了。
并且由于是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里的编码相对应的。


下面是在网上搜集关于中文乱码的一些资料.

java中文问题详解
http://www.cn-java.com/target/news.php?news_id=210
关于Java中文问题的几条分析原则http://www-900.ibm.com/developerWorks/cn/java/l-javachinese/index.shtml
全方位解决xml中文问题http://www.csdn.net/develop/read_article.asp?id=18901
servlet 中的汉字编码问题http://www-900.ibm.com/developerWorks/cn/java/jsp_dbcsz/index.shtml
Java程序的国际化和本地化介绍http://www-900.ibm.com/developerWorks/cn/java/joy-i18n/index.shtml
Java 编程技术中汉字问题的分析及解决http://www-900.ibm.com/developerWorks/cn/java/java_chinese/index.shtml
Unicode专题http://www-900.ibm.com/developerWorks/cn/theme/unicode.shtml
这里也有篇专家写的文章:
http://www.javaworld.com/javaworld/jw-04-2004/jw-0419-multibytes.html


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/shangpusp/archive/2009/04/06/4052943.aspx

分享到:
评论

相关推荐

    (Jsp+JavaBean+Struts+JDBC)学生信息管理系统

    2,系统支持国际化,采用UTF-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用Struts标签制,避免Jsp页面出java代码。 3,完全生成前台静态页面,大大提高网民浏览前台页面的速度,降低服务器的资源...

    zhicun.rar_Java 8_javabean mysql mvc_jsp 树 数据库

    系统概述: 本系统基于Java平台,采用设计模式:MVC(模型 视图 控制),采用的...2,系统支持国际化,采用UTF-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用Struts标签制,避免Jsp页面出java代码。

    ## 淘特JSP留言板-Java

    1、采用UTF-8编码,支持多国语言。2、多栏目支持,支持开通无限个数的留言板,可以为每个栏目设置独立的管理员。3、系统自带中、英文语言包,并自动判断用户所处的地区选择语言,你可以添加自己的语言包来支持其它...

    基于JSP开发的信息管理系统

    2,系统支持国际化,采用UTF-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用Struts标签制,避免Jsp页面出java代码。 3,完全生成前台静态页面,大大提高网民浏览前台页面的速度,降低服务器的资源...

    jsp开发的网上书店系统

    2,系统支持国际化,采用UTF-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用Struts标签制,避免Jsp页面出java代码。 3,完全生成前台静态页面,大大提高网民浏览前台页面的速度,降低服务器的资源...

    jsp 留言板+sql2000

    1、采用UTF-8编码,支持多国语言。 2、多栏目支持,支持开通无限个数的留言板,可以为每个栏目设置独立的管理员。 3、系统自带中、英文语言包,并自动判断用户所处的地区选择语言,你可 以添加自己的语言包来支持...

    java信息管理系统

    2,系统支持国际化,采用UTF-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用Struts标签制,避免Jsp页面出java代码。 3,完全生成前台静态页面,大大提高网民浏览前台页面的速度,降低...

    淘特Jsp内容管理系统(Cms) v3.0.zip

    可以满足一台普通server环境下提供 百万级的访问量,系统提供高效的索引技术,搜索数百万级的文章内容仅在毫秒之内,国际化utf-8编码,支持多国语言,真正一套国际化门户网站解决方案   本系统使用三层架构(淘特...

    志远信息管理系统 V2.0.rar

    2,系统支持国际化,采用utf-8编码,资源文件里可以设置多国语言,形成多国语言界面。 3,系统采用struts标签制,避免jsp页面出java代码。 4,完全生成前台静态页面,大大提高网民浏览前台页面的速度,降低服务器的资源...

    淘特大型门户网站CMS企业版

    1、采用UTF-8编码,支持多国语言(自带中英文两种语言包),目前国内仅淘特CMS有此功能。通过properties文件调用,修改定制灵活. 2、支持多浏览器,所有代码均在多种浏览器通过测试 3、可视化文本在线编辑,文章添加可...

Global site tag (gtag.js) - Google Analytics