如何解决Tomcat6中文乱码
1个回答
2018-01-22 · 知道合伙人软件行家
关注
展开全部
一、对Tomcat_HOME/conf/server.xml文件进行配置
核心代码如下(其中最后一句是自己加的):
<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
URIEncoding="GBK" /> -->123456
这种方式一般不建议使用,因为它修改的是Tomcat平台的编码,而业内没人对其不修改,如果人为修改会影响其他项目的运行。
二、逆向编码解码还原法
之所以会出现乱码,是因为浏览器将中文传给tomcat时,tomcat以默认的iso8859-1方式对其解码,而iso8859-1不属于中文码表,故而出现乱码。根据这个原理可逆向还原。
如:
byte buf[] = request.getParameter("name").getBytes("iso8859-1");String name = new String(buf,"GBK");12
这样得到的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>12345
后台形如:
request.setCharacterEncoding("utf-8");String name = request.getParameter("name");12
这样也能正确地接受中文参数了。当然,这种方式也存在弊端,试想下当项目发布后,如果需要修改编码为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>12345678
servlet示例核心代码如下:
public void init(ServletConfig config) throws ServletException {
String charset = config.getInitParameter("character");
System.out.println(charset);
}1234
这种方法弥补了方法3的缺陷,方便后期维护和修改,用户修改时不需要改源代码,只需修改web.xml即可。
核心代码如下(其中最后一句是自己加的):
<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
URIEncoding="GBK" /> -->123456
这种方式一般不建议使用,因为它修改的是Tomcat平台的编码,而业内没人对其不修改,如果人为修改会影响其他项目的运行。
二、逆向编码解码还原法
之所以会出现乱码,是因为浏览器将中文传给tomcat时,tomcat以默认的iso8859-1方式对其解码,而iso8859-1不属于中文码表,故而出现乱码。根据这个原理可逆向还原。
如:
byte buf[] = request.getParameter("name").getBytes("iso8859-1");String name = new String(buf,"GBK");12
这样得到的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>12345
后台形如:
request.setCharacterEncoding("utf-8");String name = request.getParameter("name");12
这样也能正确地接受中文参数了。当然,这种方式也存在弊端,试想下当项目发布后,如果需要修改编码为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>12345678
servlet示例核心代码如下:
public void init(ServletConfig config) throws ServletException {
String charset = config.getInitParameter("character");
System.out.println(charset);
}1234
这种方法弥补了方法3的缺陷,方便后期维护和修改,用户修改时不需要改源代码,只需修改web.xml即可。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询