这几天在使用ExtJS 在修改数据时提交到后台居然是乱码,Post方法到后台的没有问题,乱码是get方法的数据。
我们的项目是国内的项目,所以字符集就默认为GBK了,我怀疑ExtJS在submit数据时用UTF-8编码的,所以将所有的地方都改成了
UTF-8,然而问题依旧。
还是静下心来用最古老的方法,看页面提交过来的到底是啥格式。
String t1=new String(name.getBytes("GBK"),"UTF-8");
String t2=new String(name.getBytes("ISO-8859-1"),"UTF-8");
发现页面提交过来的居然是GBK,怎么可能啊。我把Server.xml, web.xml, *.jsp, *.js 这些文件中都修改成UTF-8了啊。难道还有遗漏的地方么?经过仔细查找后来发现了 struts2.properties 这个文件中 如下两句话
struts.locale=zh_CN
struts.i18n.encoding=GBK
把GBK改成UTF-8后乱码问题解决。
问题总结如下:有些开源的插件,默认的编码格式是ISO-8859-1的,或者是UTF-8的,在中文环境中容易出现乱码问题,必须要做强制转码,而UTF-8是最大最全的一个编码字符集,大家都向UTF-8看齐了就不会出现转码过程中的乱码问题。
因为我的系统就只给中国人用,所以将编码定为GBK是非常不好的。
以下是我的UTF-8编码需要配置的几个地方,供大家参考:
1 Web.xml 增加spring提供的转码类
在这里加了转码类就不需要在Server.xml中增加 URIEncoding="UTF-8"了
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/dwr/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
2 修改JSP页面,编码为UTF-8格式
<%@ page language="java" pageEncoding="UTF-8" contentType="text/html;charset=UTF-8" %>
3 html 页面,编码为UTF-8格式
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
4 所有的JS脚本,文件编码也为UTF-8
5 最彻底的,在eclipse下- windows-preference-general-content Type 下
将所有的格式都变为UTF-8编码
6 容易遗漏的还是 struts2.properites
struts.locale=zh_CN
struts.i18n.encoding=UTF-8
这下乱码问题解决了吧?
如果还没有解决 ,估计就是有的开源组件给硬编码写ISO-8859-1了,没好的办法,
在乱码的地方使用我的绝招吧:
name=new String(name.getBytes("ISO-8859-1"),"UTF-8");
强制转为UTF-8.
总结:只要大家都向UTF-8看齐了,就不会存在乱码问题,除非UTF-8编码中没有这个字的编码。