困扰了多长时间记不住了,今天终于解决了,天哪 -_-!!!
如题目配置,中文显示总是有问题,在hibernate缓存中是正常的中文,当存到MYSQL数据库中再读出就是乱码,也就是读入hibernate缓存、存入数据库、读出数据库这几个过程转码,真是没有个转啊。
终于试出这个方法:(注本人机器上是正常了,仅作为你的参考吧)
1、mysql5.0安装时选GBK编码,如已安装可通过配置改一下,或找到安装目录下的my.ini文件,打开,找到default-character-set=latin1设成default-character-set=gbk,找到:sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"注释掉,不然插入汉字时会出现data too long ...,保存。
2、重启mysql,不知道在哪重启?呵呵,我也是。在控制面板-管理工具-服务里重启,这时可以用mysql-front试试插入汉字看看正常不正常。
3、所有JSP文件第一行为<%@ page language="java" contentType="text/html; charset=gbk"%>
4、数据库连接的url=jdbc:mysql://localhost:3306/?useUnicode=true&characterEncoding=GBK,必须要有这个。
5、加过滤器:SetEncodingFilter.java
package com.wangbass.struts;
import java.io.IOException;
import javax.servlet.*;
public class SetEncodingFilter implements Filter {
// default character encoding
String defaultEncoding = "gbk";
public void init(FilterConfig config) throws ServletException {
String encoding = config.getInitParameter("encoding");
if (encoding != null) {
defaultEncoding = encoding;
}
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
request.setCharacterEncoding(defaultEncoding);
chain.doFilter(request, response);
}
public void destroy() {
defaultEncoding = null;
}
}
在web.xml中配置过滤器:
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>com.wangbass.struts.SetEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>gbk</param-value>
</init-param>
<init-param>
<param-name>ignore</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
至此完成,祝好运!