说明:之前一直没有遇到过这个问题,网站全部用UTF-8 tomcat也是用UTF-8 ,Mysql在安装的时间也是选 UTF-8,
但总是在保存到数据的时候 变成 ???, 但从数据库中读取出来的也正常显示.
今天搞了一天,没有发现问题的所在,最后确定在程序跟SQL 数据库的出了问题,最后发现这篇文章。
按下面的步骤修改一下,才发现,在安装MYSQL的时候,虽然也选了UTF-8 在它的配置文件却不是UTF-8,最后修改MY.ini
重启MYSQL服务,搞定。
1.修改my.ini文件
修改mysql的my.ini配置文件的默认编码 default-character-set=utf8 。
两处地方都要改 (之前我就是只修改一处,结果没有成功)
修改my.ini配置文件后要重启mysql服务
执行net start mysql是启动mysql服务
执行net stop mysql是停止mysql服务
2.修改data目录中相应数据库目录下的db.opt配置文件
default-character-set=utf-8
default-collation=utf8_general_ci
3.在创建数据库时指定字符集
create database yourDB CHARACTER SET gbk;
4.数据库连接串中指定字符集
URL=jdbc:mysql://localhost:3306/c2c? useUnicode=true&characterEncoding=UTF-8("&"在eclipse中要写作"&" )
注:在mysql4.1.0版 要加useUnicode=true&characterEncoding=UTF-8
如果是5.0版以上的,加不加都是没有关系的!
5.web.xml配置过滤器或struts-config.xml配置控制器
过滤器
web.xml代码
<filter>
<filter-name>
Character Encoding
</filter-name>
<!--这里填写类的完整路径-->
<filter-class>myc2c.util.SetEncodeFilter</filter-class>
<init-param>
<param-name>defaultencoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>
Character Encoding
</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
java代码
public class SetEncodeFilter implements Filter {
protected FilterConfig filterConfig = null;
protected String defaultEncoding = null;
public void init(FilterConfig arg0) throws ServletException {
this.filterConfig = arg0;
this.defaultEncoding = filterConfig.getInitParameter("defaultencoding");
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
request.setCharacterEncoding("UTF-8");
chain.doFilter(request, response);
}
public void destroy() {
this.defaultEncoding = null;
this.filterConfig = null;
}
}
控制器
struts-config.xml代码
<!--填写类的完整路径-->
<controller processorClass="myc2c.processor.EncodingProcessor"></controller>
java代码
public class EncodingProcessor extends RequestProcessor {
public void process(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
super.process(request, response);
}
}
转自:http://blog.csdn.net/vstree/archive/2009/01/20/3844107.aspx
感谢以上文章让我解决这个我花了一天时间都没有解决的问题.