遇到了一个问题,在开发时上传文件时,文件的中文名上传的是中文乱码,所解决方法:
文章转载自:https://blog.csdn.net/lengjinghk/article/details/51938644
一、对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="utf-8" />
或者
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即可。