`
anysky131
  • 浏览: 177607 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Tomcat5+Mysql中文乱码问题的解决方法

阅读更多

Tomcat 下最容易到的问题就是中文乱码问题了,下面就来谈谈我在Windows +Tomcat5下调试JSP程序时,所碰到的问题以及解决办法。

这次调试所遇到的乱码问题主要有三类:

一、页面字符乱码。

即整个页面出现汉字乱码(不管是用HTML格式写的,还是用print()方法输出的汉字,全部显示为乱码)。

二、Request 传递乱码。

在用postget等方法,传递变量时出现乱码;需要进行cookies或者session调用时出现乱码。

三、数据库存取乱码。

在进行数据库存取时,或者存入数据库,或者读出数据时出再乱码。

下面就这三类乱码进行分析并谈谈我的解决方法:

一、页面字符乱码。

我们先写下这样的一个jsp文件:

//testPagErr.jsp

<%

out.println(“能显示中文吗?”);

%>

如果我们直接按照默认的配置启动Tomcat5,然后访问这一个页面的时,将输出的中文将显示为乱码。其原因很简单,这是由于在Tomcat5 默认的设置下,将按照ISO-8859-1进行编码。解决这个问题最直接的做法是,有每个有中文输出的jsp文件的开头加一句:

<%@ page contentType="text/html;charset=GBK" //(改成GB2312亦可,本文中均以GBK为例)%>

但是这样做存在很多问题,首先,这一句开指令在include的时候,不能够被子文件继承,因此,我们必须在子文件中重新加入这一句话,但如果大小写不话,就会出现类似于以下的错误:

org.apache.jasper.JasperException: /top.jsp(1,1) Page directive: illegal to have multiple occurrences of contentType with different values (old: text/html;charset=gbk, new: text/html;charset=GBK).

那么,这样子定义就有点恐怖了,假如有一个要作Head.jsp的头文件,我们试着在其中加入<%@ page contentType="text/html;charset=GBK" %>要在众多的文件中被包含,而这些文件是由不同的程序只写的,有的习惯用“gbk,有的用“GBK”,还有喜欢用“GB<chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="False" sourcevalue="2312" unitname="”">2312<span lang="EN-US" style="font-family: 宋体;"><span lang="EN-US">”</span></span></chmetcnv>,那怎么办啊?难到要一个文件一个文件地去改过来?就算你可以用一些编辑器Replace in Files功能把所有的文件更正过来,但这样做必然会影响系统的可移植性。

同样,如果"text/html;charset=GBK"的间隔不一致的话,也会出错,而且,一旦程被修改成这样的模式,你的程序就不能在旧的jsp/servlet container上执行了,因为旧的规格是不允许在include文档中再次中现<%@ page ... %>这样的定义的。

因此上,如果采用上述方法的话,在一两个页面上也可行,但此法仅为权益之计。

J2EE1.4中,关于jsp的部分里有一个<jsp-config> XML Tag,这个区块是用来定义jsp的相关特殊属性的,它包含所采用的taglib和下面我们要用到的<jsp-property-group>,定义字符编码的方法就定义在<jsp-property-group>之中,找到你正在开发的webapps目录(一般在$TOMCAT_HOME\webapps\your_web_site\)下的WEB-INF,打开web.xml(如果没的话,就创建一个),作如下修改:

<?xml version="1.0" encoding="ISO-8859-1"?>

<!— 这一段是xml head的定义,特别注意,最后的version="2.4"Tomcat5会去检测这个版本的信息,只有2.4的才会去处理jsp-config中的参数 -->

<web-app xmlns="http://java.sun.com/xml/ns/j2ee"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee web-app_2_4.xsd"

version="2.4">

<!— ------------------------------------------------------------------------------------------ -->

<!— 这一部分就是我们新加入的,起作用的区块 -->

<jsp-config>

<jsp-property-group>

<description>

Special property group for JSP Configuration JSP example.

</description>

<display-name>JSPConfiguration</display-name>

<url-pattern>*.jsp</url-pattern>

<el-ignored>true</el-ignored>

<page-encoding>GBK</page-encoding>

<scripting-invalid>flase</scripting-invalid>

<include-prelude></include-prelude>

<include-coda></include-coda>

<description>

Special property group for JSP Configuration JSP example.

</description>

<display-name>JSPConfiguration</display-name>

<url-pattern>*.html</url-pattern>

<el-ignored>true</el-ignored>

<page-encoding>GBK</page-encoding>

<scripting-invalid>flase</scripting-invalid>

<include-prelude></include-prelude>

<include-coda></include-coda>

</jsp-property-group>

</jsp-config>

<!— ------------------------------------------------------------------------------------------ -->

</web-app>

另外,如果Tomcat5Apache整和,最好把httpd.conf中的AddDefaultCharset的值设为GBK.

二、equest传递乱码

按照Tomcat的默认设置,在通过表单提交的数据将出现乱码,其原因是中文字符的高位被丢失,如:

成龙的unicode 6210 9f99 ,但是从request里面读出来的是: 10 99

其原因是form表单和request方法中设置的编码格式不一致,在上面,我们已经将页面编码改成了GBK,因此上,我们只须将request的编码改为GBK即可。

比较简单的解决方法是,在要用到request方法的地方加上这条语句:request.setCharacterEncoding("GBK");

但这也将遇到与第一种方法同样,当几个人同时写程序时,或者,引用别人已写的程序的时候,也会存在移植不便的问题。

更好的方法是,注册SetCharacterEncodingFilter类:

$TOMCAT_HOME\webapps\your_web_site\WEB-INF\classes目录下新建一个名为filters的文件夹,然后把$TOMCAT_HOME\webapps\jsp-examples\WEB-INF\classes\filtersSetCharacterEncodingFilter.class文件拷到新建的filters下面,最后在web.xml中加入如下的两个区块:

<!-- Example filter to set character encoding on each request -->

<filter>

<filter-name>Set Character Encoding</filter-name>

<filter-class>filters.SetCharacterEncodingFilter</filter-class>

<init-param>

<param-name>encoding</param-name>

<param-value>GBK</param-value>

</init-param>

</filter>

<!-- Example filter mapping to apply the "Set Character Encoding" filter

to *all* requests processed by this web application -->

<filter-mapping>

<filter-name>Set Character Encoding</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

如果找不到SetCharacterEncodingFilter.class,也可以自己编写SetCharacterEncodingFilter.java文件,代码如下:

*

* filename: SetCharacterEncodingFilter.java

*

package filters;

import java.io.IOException;

import javax.servlet.Filter;

import javax.servlet.FilterChain;

import javax.servlet.FilterConfig;

import javax.servlet.ServletException;

import javax.servlet.ServletRequest;

import javax.servlet.ServletResponse;

import javax.servlet.UnavailableException;

public class SetCharacterEncodingFilter implements Filter {

protected String encoding = null;

protected FilterConfig filterConfig = null;

protected boolean ignore = true;

public void destroy() {

this.encoding = null;

this.filterConfig = null;

}

public void doFilter(ServletRequest request, ServletResponse response,

FilterChain chain)

throws IOException, ServletException {

// Conditionally select and set the character encoding to be used

if (ignore || (request.getCharacterEncoding() == null)) {

String encoding = selectEncoding(request);

if (encoding != null)

request.setCharacterEncoding(encoding);

}

// Pass control on to the next filter

chain.doFilter(request, response);

}

public void init(FilterConfig filterConfig) throws ServletException {

this.filterConfig = filterConfig;

this.encoding = filterConfig.getInitParameter("encoding");

String value = filterConfig.getInitParameter("ignore");

if (value == null)

this.ignore = true;

else if (value.equalsIgnoreCase("true"))

this.ignore = true;

else if (value.equalsIgnoreCase("yes"))

this.ignore = true;

else

this.ignore = false;

}

// ------------------------------------------------------ Protected Methods

protected String selectEncoding(ServletRequest request) {

return (this.encoding);

}

}

用任意一个java编译器编译即可,编译的时候注意包含servlet-api.jar包,它位于$TOMCAT_HOME\common\lib\下面。

然后删除work中的内容,然后启动Tomcat,即可显示中文了。

三、数据库存取乱码

当然,在写数据库时,也要保正数据库的编码与其它一致:

我们可以在系统盘windows目录下的my.ini文件,在文件中插入一行default-character-set=GBK,但上面说了这么多,大家也应该明白些了吧,改动太多的默认设置不是我的风格,因此上,这一行还是不要加的好。

但不管怎么样,我们还是要创建一个基于中文编码的数据库,当然,用客户端登录的时候,某些客户用自动把字体编码转换成中文编码。在这里,我想说一下在DOS下创建中文编码数据库的方法:

在进入数据库的时候,mysql--default-character-set=gbk-uroot-p这句话进入mysql然后创建数据库,如:createdatabaseadmin;这样创建起来的数据库就是基于中文编码的了。

用连接数据库的时候,读出的数据也可能是乱码,解决这个问题的方法非常简单,只要在你建立数据库连接的时候把URL设置成下面这个样子就可以了:URL=jdbc:mysql://localhost:3306/my_database?useUnicode=true&characterEncoding=GBK

好了,说了这么多,总结一句话结束吧,把各种地方的编码统一起来,那么,所在的乱码问题就都解决了!

分享到:
评论

相关推荐

    Struts+Hibernate+MyEclipse+Tomcat+MySQL的乱码之解决

    总之,要解决Struts+Hibernate+MyEclipse+Tomcat+MySQL环境中的乱码问题,你需要检查并设置以上提到的所有环节的编码,确保它们统一为UTF-8。通过这种方法,可以有效地避免乱码的出现,从而提供良好的用户体验。在...

    解决Tomcat+MySql+Struts的中文问题

    总结来说,解决Tomcat+MySql+Struts的中文问题,主要包括以下几个步骤: 1. 确保HTML/JSP页面使用支持中文的charset,如GBK或UTF-8。 2. 使用过滤器处理POST请求,设置请求的字符编码。 3. GET请求一般无需特殊处理...

    服务器CentOs6.6+ JDK1.7+Tomcat7+MySQL5.6安装部署记录

    ### 服务器CentOs6.6+ JDK1.7+Tomcat7+MySQL5.6安装部署记录 #### 一、安装CentOs6.6 **步骤解析:** 1. **下载与烧录ISO镜像:** - 首先需要下载好Linux (CentOs6.6mini) 的ISO文件,通过U盘制作工具如“大白菜...

    java+mysql 乱码

    通过以上步骤,通常可以解决Java与MySQL交互过程中的中文乱码问题。记得在每个环节都要检查并确保编码的一致性,避免因编码不匹配导致的数据乱码。如果仍然存在问题,可能需要进一步检查其他可能导致乱码的因素,...

    centos7+Tomcat+MySQL+nginx电子商务站点部署及rsync备份

    ### centos7+Tomcat+MySQL+nginx电子商务站点部署及rsync备份 #### 一、项目说明 本文档旨在提供一套完整的基于CentOS 7操作系统、Tomcat应用服务器、MySQL数据库服务器以及Nginx反向代理服务器的电子商务站点部署...

    mysql+jsp+SSH网站开发中文乱码解决方案

    通过以上步骤,可以基本解决MySQL、JSP和SSH框架集成网站开发中的中文乱码问题。在实际开发过程中,要根据项目的具体情况进行调整和测试,确保每个环节都正确处理了字符编码。如果你遇到了特定的问题,可以进一步...

    在线考试系统平台设计,框架:html + js + css + jsp + servlet + java + mysql

    开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 select version() 获取数据库版本'5.6.00' 图片无法加载是因为拦截器,修改拦截器,或者删除所有拦截器。当出现乱码在添加拦截...

    网络考试系统平台设计,框架:html + js + css + jsp + servlet + java + mysql

    开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 http://localhost:8080/exam/ select version() 获取数据库版本'5.6.00' 图片无法加载是因为拦截器,修改拦截器,或者删除所有拦截...

    myeclipse中文乱码的解决方法

    压缩包中的`中文乱码解决.txt`文件可能是对这个问题的详细步骤或解决方案的记录,建议下载并查阅,以便更具体地解决问题。 通过以上步骤,你应该能有效地解决MyEclipse中的中文乱码问题。在处理编码问题时,关键是...

    struts2的中文乱码问题解决

    ### Struts2中文乱码问题解决方案 在使用Struts2框架进行Web开发的过程中,中文乱码问题是一个常见的挑战。这不仅影响用户体验,还可能导致数据不一致等问题。为了解决这一问题,我们需要理解其背后的原理,并采取...

    MyEclipse+MYSQL使用图解

    ### MyEclipse与MySQL集成使用详解 ...以上步骤完成了MyEclipse与MySQL集成使用的详细配置流程及相关常见问题的解决方法。通过这些步骤,开发者可以轻松地在MyEclipse环境中开发和测试基于MySQL数据库的Web应用。

    解决Linux下Tomcat向MySQL插入数据中文乱码问题

    但根据描述中的尝试,这两种方法并没有解决问题。 **2. SSM框架的编码过滤器** 如果你使用的是Spring、SpringMVC和MyBatis(SSM)框架,可以在`web.xml`中配置`CharacterEncodingFilter`,确保所有请求都以UTF-8...

    JSP乱码 N种解决方案

    通过以上这些方法,基本上可以解决大部分JSP页面的乱码问题。实际开发中,应结合具体情况选择合适的方法,进行系统性的排查和调整。对于复杂的应用场景,可能需要结合多个解决方案一起使用。在日常工作中,养成良好...

    大学生毕设+基于JavaWeb带GUI界面+花店管理系统(前后端源码+数据库)

    开发环境: eclipse + jdk1.7 + tomcat7 + mysql5 使用框架: spring3.1.1 + hibernate4.1.7 + struts2.3.4 + fileupload 注意事项: 1, 运行项目前请确认db.properties配置文件中的数据库连接参数是否正确 2, 如果...

    ssm+mysql实现的Java-web酒店管理项目源码.doc

    当出现中文乱码问题时,需要修改Tomcat的`server.xml`文件,添加字符编码设置以解决问题。 10. **Web应用程序目录结构**:了解Web应用的目录结构对于正确部署项目至关重要。例如,Web-INF目录下的web.xml文件是Web...

    ssm+mysql实现的Java web酒店管理项目源码.pdf

    - 中文乱码:修改Tomcat的`server.xml`文件,添加字符集设置以解决乱码问题。 通过这个项目,学习者不仅可以了解SSM框架的实际运用,还能学习到数据库设计、Web开发流程、数据可视化以及问题排查等方面的知识,...

    java web在线考试系统,框架:html + js + css + jsp + servlet

    开发工具:ideaIC-2022.3.2.exe 或者eclipse都行 + jdk1.8 + Apache Tomcat/8.5.78 http://localhost:8080/exam/ select version() 获取数据库版本'5.6.00' 图片无法加载是因为拦截器,修改拦截器,或者删除所有拦截...

Global site tag (gtag.js) - Google Analytics