博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用UTF-8完全解决JSP+MYSQL多国语言文字编码问题
阅读量:4051 次
发布时间:2019-05-25

本文共 1798 字,大约阅读时间需要 5 分钟。

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

转载出处:

首先说明几点:

在文件中任何时候出现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");
这一步也可以用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中文问题详解

关于Java中文问题的几条分析原则
全方位解决xml中文问题
servlet 中的汉字编码问题
Java程序的国际化和本地化介绍
Java 编程技术中汉字问题的分析及解决
Unicode专题
这里也有篇专家写的文章:
 

 

你可能感兴趣的文章
重读《触龙说赵太后》
查看>>
2010的第一次思想触动
查看>>
文学大师做菜艺术20个"须知"
查看>>
SVN + 批处理 + Dropbox + TeamViewer实现远方协同工作
查看>>
vc学习之关于缩放到托盘区
查看>>
vc学习之键盘事件OnKeyDown
查看>>
近期工作
查看>>
春寒料峭,原来春天这样走近
查看>>
电脑坏了--关于联想笔记本声卡驱动
查看>>
C#中枚举类型在switch语句中值对照问题
查看>>
GridView中根据特殊标记设置不可编辑
查看>>
PowerDesinger中生成数据库时将域的内容转化为实际的字段
查看>>
通过模板将GridView导出为Excel
查看>>
迭代开发过程及一些原则
查看>>
Windows IIS服务器CA认证安装
查看>>
Asp.net 中Excel通过模板导出中发布问题
查看>>
64位机器配置CA认证一些小问题
查看>>
SVN自动完全备份
查看>>
开发中的Warning原来也很有用
查看>>
Silverlight Toolkit例子代码中缺少System.Windows.Controls.Samples.Common.dll的解决办法
查看>>