中文乱码问题及其解决办法

1.解决HTML页面中的中文问题:

为了使HTML页面很好地支持中文,就必须在每个HTML页面的头部增加如下代码:

<HEAD>

...

<META http-equiv=Content-Type content="text/html;charset=gb2312">

...

<HEAD>

2.解决JSP页面中的中文问题

<%@ page contentType="text/html;charset=gb2312" language="java"%>

3.解决Servlet请求和响应结果的中文问题

为了使Servlet页面很好地支持中文,就必须在每个Servlet页面的头部增加如下代码:

response.setCharacterEncoding("gb2312");

request.setCharacterEncoding("gb2312");

4.解决页面数据传输的中文问题

为了使中文数据在各页面(组件)之间正常传递,最佳的方法就是采用编码过滤器来解决。在WEB.XML中配置一个编码过滤器,内容如下:

<!--定义编码过滤器-->

<filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>

<init-param>

<param-name>encoding</param-name>

<param-value>gb2312</param-value>

</init-param>

</filter>

<filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

5.解决HTTP(get)请求中的中文问题:

在默认情况下,IE浏览器发“ISO-8859-1”的编码格式发送请求,如果接收到HTTP的get请求中文参数时出现乱码,就可以对其进行编码转换,例如:

String param = request.getParameter("param");

param = new String(param.getBytes("ISO-8859-1", "GB2312"));

也可以通过修改Tomcat的server.xml文件来解决:

<Connector port = "8080"

...

URIEncoding="GB2312"/> -->增加这项

6.解决MySQL数据库的中文问题:

解决MySQL数据库中文问题主要在JDBC驱动的URL上,例如:

jdbc:mysql://localhost/test?user=root&password=123456&useUnicode=true&characterEncoding=gb2312

在设计数据表的时候也要指明其编码方式。

问题总结: 编码问题其实就是编码的一致性问题,只要是编码可以支持中文并且在传输数据和显示数据的各个阶段编码保持一致就不会出现乱码问题。

其实把上面的gb2312改成utf-8也是可以的。除了乱码问题就要找是不是在数据传输和表现的过程中是不是有编码不支持中文或者编码不一致的问题,其实把发生乱码问题的原因搞清楚了,问题就能够很好的解决了。

他山之石:http://blog.csdn.net/beijiguangyong/article/details/7414247

http://blog.csdn.net/tkd03072010/article/details/6667689

时间: 2024-10-12 05:29:28

中文乱码问题及其解决办法的相关文章

get/post时中文乱码问题的解决办法

常有的方法,get请求用在tomcat的编码改为utf-8 即可 post 过滤器就可以 一.常识了解 1.GBK包含GB2312,即如果通过GB2312编码后可以通过GBK解码,反之可能不成立; 2.java.nio.charset.Charset.defaultCharset() 获得平台默认字符编码: 3.getBytes() 是通过平台默认字符集进行编码: 二.中文乱码出现 在学习任何一门技术时,经常会有初学者遇到中文乱码问题,比如MySQL,是因为在安装时没有设置:而在Servlet中

eclipse中文乱码问题的解决办法

今天下午纠结这个乱码问题.简直要醉了. 网上有很多类似的问题,类似的解决办法. 至于有效性,其实也多为一个运气.因为谁知道eclipse的编码机制呢. 导入别人的项目,难免遇到几个中文汉字.真遇到怎么办呢. 1. 先检查原.zip或.tar文件是否受损.办法:解压后,用记事本打开.java文件.无乱码说明该文件未受损.可另存为,查看它的编码方式A(utf-8或其他). 2. 导入包后,jre环境配置好后,右击项目查看其默认编码方式(一般utf-8或gbk). 3. 若.java文件打开有乱码出现

codeblocks中文乱码原因及解决办法

原因:(本地化做得不够好)默认情况下codeblocks编辑器保存源文件是保存为windows本地编码,就是WINDOWS-936字符集,即GBK:但CB的编辑器在默认编辑的时候是按照UTF-8来解析的,由于源文件的编码与编辑器的编码没有统一好,从而造成代码中的中文字符乱码. 解决办法:只要将源文件的编码与编辑器的解析编码统一即可,具体步骤如下①setting→editor→encoding setting→选择WINDOWS-936与As default encoding ②setting→c

jQuery使用serialize()表单序列化时出现中文乱码问题的解决办法

序列化中文时之所以乱码是因为.serialize()调用了encodeURLComponent方法将数据编码了 解决方法就是进行解码 原因:.serialize()自动调用了encodeURIComponent方法将数据编码了 解决方法:调用decodeURIComponent(XXX,true);将数据解码 //商品标签function tag(url){ var form = $('form').serialize(); //序列化内容 var shuju = decodeURICompon

Linux系统中关于Sqlite3中文乱码问题及解决办法

新做的一个项目在本地(Win8)测试时没有问题,但传到服务器(Linux)时从Sqlite3数据库查询到的数据中文却是乱码(数据库中是正常的) 将php文件.html文件都设置成统一的utf8还是一样,在网络上也找了各种解决方案都没有任何用. 解决办法: 将查询到的数据重新处理,全部强制转换成UTF8 //打开db.db表 $db = new SQLite3('db.db'); if(!$db){ echo $db->lastErrorMsg(); exit; } else { } $keys

Pycharm 输出中文或打印中文乱码现象的解决办法

1. 确保文件开头加上以下代码: 1 # -*- coding:utf-8 -*- 还可以加上 1 import sys 2 reload(sys) 3 sys.setdefaultencoding('utf-8') 确保以下. 如果还是没有解决中文乱码,那么进行方法2. 2. 进入setting 单击打开,单击 修改完成后,结果如下 单击“ok”. 成功.

web 前端:连接mysql中文乱码问题的解决办法

当使用tomcat部署servlet连接时,总是出现各种原因的中文乱码问题.有的是因为mysql的默认字符集的问题,有的是客户端的字符配置问题. 现在对于这两种问题进行配置,来解决乱码. 服务器端(mySQL)的字符集配置: show charset://显示支持的所有字符集,大约有40多种: SHOW VARIABLES LIKE 'character_set_%';//查看SQL使用的编码格式: set character_set_client = utf8;//将SQL的一个属性改为utf

get/post时中文乱码问题的解决办法(转载)

1.文章1 最近遇到一个问题:用get方法传递中文有问题,用post没有问题. 问题简单的描述是这样的: <a href="userGroup.jsp?userGroupName=<%=userGroupName%>">aa</a> 这里userGroupName是中文 在userGroup.jsp页面得到的userGroupName却是乱码. 每个页面也都有<%@ page language="java" pageEnco

PHP中文乱码分类及解决办法大全

PHP+MYSQL做网站开发通常都会碰到浏览器输出中文字符时乱码,这个问题的原因主要是因为HTML内容编码,PHP文件编码和MySQL数据库编码这三者不一致造成的.下面我们以UTF-8为例简述一下如何统一这三者之间的关系. 新增一个PHP文件,命名为test_charset.php,将下面的代码保存到该文件中: <?php $charset = "utf8"; $con = mysql_connect("localhost", "root"