ssh 保存到数据库 乱码

来源:互联网 发布:英译汉翻译软件 编辑:程序博客网 时间:2024/06/18 09:42

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

 

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