Java对于新手最容易出现的问题就是中文乱码的问题。今天我就来总结一下彻底解决Spring mvc+Mybatis中文乱码的方案。
首先要看打一断点看一下Controller接收到参数值是否正常。如果不正常多半是因为Spring或者页面编码的设置问题。
遇到的问题:
public @ResponseBody String cancleask(...) throws UnsupportedEncodingException {
RSResult result = new RSResult();
try {
Ask cond = new Ask();
String newcancelReason = new String(cancelReason.getBytes("iso-8859-1"),"utf-8");
cond.setCancelReason(newcancelReason);
cond.setAskid(Integer.parseInt(askid));
cond.setStatus(Integer.parseInt(userType)==3?6:5);
if (askid != null && !askid.equals("")) {
int retval = askBiz.cancleAsk(cond);
result.setResult(retval);
result.setMessage("取消咨询ok!");
} else {
result.setResult(-1);
result.setMessage("取消咨询error!");
}
} catch (BizException ex) {
log.error("取消咨询 :" + ex.getMessage());
result.setResult(-1);
result.setMessage("取消咨询error!");
}
return JSONObject.fromObject(result).toString();
}
加上这一行导致 添加数据到数据库的是乱码。
一、Spring或页面编码问题
在JSP页面第一行加上下面代码:
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
因为Springmvc采用默认的编码(ISO-8859-1)进行解析参数, 这时就会出现乱码问题。
在Web.xml加上Spring编码转换过滤器filter。
- <filter>
- <filter-name>encodingFilter</filter-name>
- <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
- <init-param>
- <param-name>encoding</param-name>
- <param-value>utf-8</param-value>
- </init-param>
- <init-param>
- <param-name>forceEncoding</param-name>
- <param-value>true</param-value>
- </init-param>
- </filter>
- <filter-mapping>
- <filter-name>encodingFilter</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
二、Web容器的问题
如果上面方案一还没有解决乱码的问题,看一下你的Web容器的问题的编码设置,比如我使用的是Tomcat,找到server.xml。
可以看到Connector没有设置编码。加上编码属性URIEncoding,如下:
- <Connector port="8081" protocol="HTTP/1.1"
- connectionTimeout="20000"
- redirectPort="8443" URIEncoding="UTF-8"/>
端口我使用是8081。上面主要是解决GET请求中文乱码的问题。
三、数据库或者链接数据库问题
如果通过打断点看到Spring Controller接收到值中方是正常的,但是插入数据库之后就是乱码了。一般这种情况无非就是两种问题。
1、数据库编码、表编码、列编码依次检查是否是UTF-8编码
2、mysql的链接字符串加上编码参数,如下:
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" value="com.mysql.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://127.0.0.1:3306/lanhuprivi?useUnicode=true&characterEncoding=UTF-8"/>
- <property name="username" value="root"/>
- <property name="password" value="root"/>
- </dataSource>
- </environment>
- </environments>
四、Response或者Servlet乱码问题
第一种方法:
- //getWriter()方法将 输出编码设置成iso-8859-1,这样输出utf8编码字符串必然乱码
- PrintWriter pw = response.getWriter();
- //1、
- //response.setCharacterEncoding("UTF-8");
- //2、
- response.setContentType("text/html; charset=utf-8");
- pw.write(resStr);
- pw.flush();
- pw.close();
setContentType 和 setCharacterEncoding两方法中设定characterEncoding的方法对服务器效果一致,不需要反复调用。
在输出文本内容时,采用response.setContentType("text/html; charset=utf-8");似乎更为方便。
第二种方法:
- PrintWriter out = new PrintWriter(new OutputStreamWriter(new FileOutputStream(), "UTF-8"));