ssh 保存到数据库 乱码

  说明:之前一直没有遇到过这个问题,网站全部用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

 

感谢以上文章让我解决这个我花了一天时间都没有解决的问题.

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值