Tomcat解决中文乱码的几种方式

来源:互联网 发布:用友软件待遇 编辑:程序博客网 时间:2024/06/06 01:31

一、对Tomcat_HOME/conf/server.xml文件进行配置(本机的完整目录为D:/Users/Administrator/Tomcat/apache-tomcat-7.0.54/conf/server.xml)
核心代码如下(其中最后一句是自己加的):

<Connector executor="tomcatThreadPool"        port="8080" protocol="HTTP/1.1"        connectionTimeout="20000"        redirectPort="8443"        URIEncoding="GBK" /> -->

这种方式一般不建议使用,因为它修改的是Tomcat平台的编码,而业内没人对其不修改,如果人为修改会影响其他项目的运行。

二、逆向编码解码还原法
之所以会出现乱码,是因为浏览器将中文传给tomcat时,tomcat以默认的iso8859-1方式对其解码,而iso8859-1不属于中文码表,故而出现乱码。根据这个原理可逆向还原。
如:

byte buf[] = request.getParameter("name").getBytes("iso8859-1");String name = new String(buf,"GBK");

这样得到的name便是前台传来的正确的中文参数了
这种方式比较偏向底层,而且有一个弊端,就是当浏览器传送的中文参数很多时,需要一个个设置,比较罗嗦,不利于节省时间。

三、将浏览器的表单的提交方式设为post方式,同时在servlet里在接受参数前将request的编码设置为GBK或者UTF-8。
前台形如:

<form action="login.jsp" method="post">    用户名:<input type="text" name="name"><br/><br/>    密    码:<input type="text" name="pwd"><br/><br/>    <input type="submit" value="登录"></form>

后台形如:

request.setCharacterEncoding("utf-8");String name = request.getParameter("name");

这样也能正确地接受中文参数了。当然,这种方式也存在弊端,试想下当项目发布后,如果需要修改编码为GBK,则要修改源代码,而对客户而言,这需要反编译等步骤直接修改代码,有点困难。

四、通过web项目的WebRoot/WEB-INF/web.xml文件进行配置参数,同时可在servlet中进行读取。
web.xml的示例核心代码如下:

<servlet>    <servlet-name>login</servlet-name>    <servlet-class>cn.hncu.servlets.LoginServlet</servlet-class>    <init-param>        <param-name>character</param-name>        <param-value>GBK</param-value>    </init-param></servlet>

servlet示例核心代码如下:

public void init(ServletConfig config) throws ServletException {    String charset = config.getInitParameter("character");    System.out.println(charset);}

这种方法弥补了方法3的缺陷,方便后期维护和修改,用户修改时不需要改源代码,只需修改web.xml即可。

1 0