Mysql5.0+hibernate中文问题解决方法

困扰了多长时间记不住了,今天终于解决了,天哪 -_-!!!

如题目配置,中文显示总是有问题,在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&amp;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>

至此完成,祝好运!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值