相信使用数据库进行存储的大家都遇到过中文乱码问题,如何彻底解决?我百度了很多资料与博客,想把自己的经历总结起来给大家参考一下,接下来我先罗列一下大部分修改乱码问题的方法:

1.   修改MySQL数据库的整体编码

引用自:http://www.cnblogs.com/24la/p/update-mysql-default-character.html

查看方式数据库编码:

show variables like 'character%';

该图是复制的(我的已经改好了)

出现上图情况时,可以进行数据库配置文件my.ini 文件修改:

打开my.ini找到[client]添加一行

default-character-set=utf8

找到[mysqld]这行添加代码如下

character_set_server=utf8

init_connect='SET NAMES utf8'

要记住,一般该配置文件是拒绝访问的,更别提修改了,此时可以将该文件复制到桌面,修改为txt格式强行修改内容,然后改回ini文件格式并将之前的my.ini文件删除,然后将桌面上已经修改好的my.ini复制进去(这一系列操作都需要管理员权限才行)

这样我们再查看下数据库的编码(我们必须关闭MySQL服务和关闭MySQL现有会话,保证我们以新的字符编码打开了)

但此时我的乱码问题依然没有解决,于是我将目光转向了eclipse。

2.   修改eclipse的页面编码

在eclipse中的window—preferences—General—workspace—页面左下角中的Text file encoding 设置为utf-8,这样只能保证新建文件和打开文件时不会出现乱码。

3.   修改JDBC连接属性编码

有一次乱码问题是通过在jdbc连接属性中的url=jdbc:mysql://localhost:3306/contact_sys的最后加入?useUnicode=true&characterEncoding=utf-8,就像是在Get请求在url下加入一下参数一样,这样就确保了java与mysql进行连接时的编码统一,很遗憾,还是没解决我的问题。

4.   修改JSP页面编码和tomcat服务器编码

引用自:http://blog.csdn.net/lhfeng/article/details/6311787

里面的一句话成功的吸引了我的注意:Tomcat默认使用iso-8859-1进行提交的数据解码,而提交的数据是使用utf-8编码的,编解码对不上自然会出现乱码.解决办法就是指定解码方式。

于是我决定彻底解决问题:在tomcat/cof/server.xml配置文件中,修改其默认编码

找到如下代码:

<Connector port="8080"protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/>

在其中加入如下代码:

useBodyEncodingForURI="true" URIEncoding="UTF-8"

其实该方法的作用很局限:当你已经设置了request.setCharacterEncoding("UTF-8");时,所有的post请求都会按照UTF-8的编码来编解码,只有Get请求在处理时会按照Tomcat的默认编码来解码,因此这项措施是针对获取get请求参数数据中文乱码的问题方法。

5.   增加过滤器类

为了彻底杜绝所有请求与响应数据的编码不一致问题,第一个想到的解决方案应该就是添加过滤器了。

public classSetEncodingFilter implements Filter {

public voiddoFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {

              request.setCharacterEncoding("UTF-8");

              response.setCharacterEncoding("UTF-8");

              chain.doFilter(request, response);

       }

}

我设置了拦截所有资源,即在项目的web.xml中进行如下配置:

<filter-mapping>

   <filter-name>SetEncodingFilter</filter-name>

    <url-pattern>/*</url-pattern>

</filter-mapping>

满心欢喜的以为应该解决问题了,结果空欢喜一场。

6.   修改fileupload获取带文件的表单数据编码

引用:http://blog.csdn.net/jingyuwang1/article/details/21829605

这个兄弟给了一个想法:既然前前后后所有的问题都设置好了,会不会是这里出了问题?

将 item.getString();改为item.getString('utf-8');

结果真的是这里的问题!终于解决了眼下的乱码问题。

7.   总结

MySQL写入的中文乱码很有可能是JSP页面提取数据时乱码或者数据库编码与写入数据的编码不一致导致的,其他的地方一般不会出错,向上面一步步设置应该可以杜绝几乎所有的乱码问题了吧。

这次解决乱码问题让我觉得处理问题时对整个流程的理解和掌握特别重要,这样你就可以一步步的检查,修改,对照,一定会把问题给找出来,并且会学到很多深层的知识,对后期解决新的问题提供了经验。

当然了,出现问题多上百度查一下,从不同的角度搜索,也是很重要的,很多问题大家都遇到过了,耐心找一找就会得到答案。

写入MySQL中文乱码问题的更多相关文章

  1. 总结--解决 mysql 中文乱码

    首先分析一下导致mysql 中文乱码的原因: 1.建表时使用了latin 编码 2.连接数据库的编码没有指定 3.写入时就已经乱码(这种情况需要自己检查源数据了) 解决方法总结: 1.创建库时指定编码 ...

  2. php mysql 中文乱码解决方法

    本文章向码农们介绍php mysql 中文乱码解决方法,对码农们非常实用,需要的码农可以参考一下. 从MySQL 4.1开始引入多语言的支持,但是用PHP插入的中文会出现乱码.无论用什么编码也不行 解 ...

  3. c#+mysql 中文乱码

    c#+mysql 中文乱码 遇到一个奇怪的问题,C#读取mysql中文正常,写入时发生乱码 网上查阅原因,发现如下信息 ---------------------------------------- ...

  4. Mysql中文乱码以及导出为sql语句和Excel问题解决

    Mysql中文乱码以及导出为sql语句和Excel问题解决 这几天基于Heritrix写了一个爬虫,用到mysql,在导入导出数据时,遇到一些乱码问题,好不容易解决了,记录一下,以备查看.一.导出数据 ...

  5. 解决springmvc+mybatis+mysql中文乱码问题【转】

    这篇文章主要介绍了解决java中springmvc+mybatis+mysql中文乱码问题的相关资料,需要的朋友可以参考下 近日使用ajax请求springmvc后台查询mysql数据库,页面显示中文 ...

  6. Servlet、MySQL中文乱码

    1.Servlet中文乱码: 在doPost或doGet方法里,加上以下两行即可: response.setContentType("text/html;charset=UTF-8" ...

  7. windows mysql 中文乱码和中文录入提示太大错误的解决方法

    今天操作mysql的时候很郁闷,因为修改默认字符集搞了半天,终于弄成了(关于如何把windows的默认字符集设置成功,可以参看另一篇博文,最终在mysql中输入show variables like ...

  8. MySQL编程(0) - Mysql中文乱码问题解决方案

    MySQL 5.6 for Windows 解压缩版配置安装: http://jingyan.baidu.com/article/f3ad7d0ffc061a09c3345bf0.html MySQL ...

  9. MySQL及navicat for mysql中文乱码

    转载自:https://www.cnblogs.com/mufire/p/6697994.html 修改完之后记着重启mysql服务,在服务里边重启,即可生效! 全部使用utf8编码 MySQL中文乱 ...

随机推荐

  1. 07 Java的方法 何谓方法

    Java的方法 1.何谓方法 System.out.println(); 那么它是什么呢? System是系统的类,out是System下的一个输出对象,println()就是一个方法 类.对象.方法 ...

  2. 作为一名Python开发,我谈Linux和mac的使用体验

    我是一名Python开发,在2018.7~2021.6使用的是Linux系统 Deepin OS 作为自己的开发系统:在2022.7-至今使用的是 mac OS 系统作为开发系统. Deepin OS ...

  3. Maven——setting.xml配置

    <settings> <localRepository>C:\Users\gcl\.m2\repository</localRepository> <serv ...

  4. Arcgis 离线部署api 4.x的两种本地部署方法!

    引言:本文用的是api4.6版本 方法一  拷贝api进去tomcat服务器用绝对地址引用 首先将下载好的api放入Tomcat服务中的Webapp下: 1  可以打开下载好的的 api46/arcg ...

  5. 6月5日 python学习总结 jQuery (二)

    1. 操作样式     对CSS类的操作: addClass();// 添加指定的CSS类名. removeClass();// 移除指定的CSS类名. hasClass();// 判断样式存不存在 ...

  6. 内网渗透----Token 窃取与利用

    0x00 前言 在之前的文章<渗透技巧--程序的降权启动>介绍了使用 SelectMyParent 降权的方法,本质上是通过 token 窃取实现的.这一次将要对 token 窃取和利用做 ...

  7. [SHA2017](web) writeup

    [SHA2017](web) writeup Bon Appétit (100) 打开页面查看源代码,发现如下 自然而然想到php伪协议,有个坑,看不了index.php,只能看 .htaccess ...

  8. JS如何通过月份,计算月份相差几个月

    1 var tr = ''; 2 <script> 3 $.each(data, function (index, item) { 4 let startTime = new Date(i ...

  9. 二叉树:前序遍历、中序遍历、后序遍历,BFS,DFS

    1.定义 一棵二叉树由根结点.左子树和右子树三部分组成,若规定 D.L.R 分别代表遍历根结点.遍历左子树.遍历右子树,则二叉树的遍历方式有 6 种:DLR.DRL.LDR.LRD.RDL.RLD.由 ...

  10. bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥)

    bzoj4596/luoguP4336 [SHOI2016]黑暗前的幻想乡(矩阵树定理,容斥) bzoj Luogu 题解时间 看一看数据范围,求生成树个数毫无疑问直接上矩阵树定理. 但是要求每条边都 ...