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
感谢以上文章让我解决这个我花了一天时间都没有解决的问题.
- ssh 保存到数据库 乱码
- 利用SSH框架讲表单提交保存到数据库乱码
- Hibeinate 保存到数据库中乱码问题
- 页面修改保存到数据库中乱码
- 从jsp页面保存到数据库乱码
- SSH将Excel中的数据读入保存到数据库中
- springMVC保存数据到mysql数据库中文乱码问题解决方法
- PHP+MySQL中文数据保存到数据库乱码的解决方法
- 数据库保存汉字乱码
- SSH系列-数据库乱码
- 【JSP页面表单提交,controller接收为乱码,以及保存到数据库时为乱码】解决方法
- 保存图片到数据库
- 保存图片到数据库
- 保存图片到数据库
- 保存图片到数据库
- 文件保存到数据库
- 保存图片到数据库
- 保存图片到数据库
- 无限级Js树型菜单(可刷新)dTree
- 未来在哪里
- 2009资格赛A题 small文件的比较笨的解决办法
- 开始写博客咯。。。
- TPM-C和TPC-C值
- ssh 保存到数据库 乱码
- Hashtable 简述
- IDE:eclipse, language:java; db:db2 ; dbDriver:jdbc(2)
- 获取按键值应用数码进行显示同时通过串发送到PC上进行显示
- LSOF 和 FUSER
- Apache Tomcat 无法启动服务
- 华为宣讲。。。
- 编码规范
- swish-e搜索引擎,代码分析(8)