首先使用比较容易的Filter来处理乱码:(示例)
ForCharacterFilter.java文件:
package cn.edu.bzu; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class ForCharacterFilter implements Filter{ private String characterEncoding; private boolean enabled; public void init(FilterConfig config){ characterEncoding=config.getInitParameter("encoding"); enabled="true".equalsIgnoreCase(config.getInitParameter("using").trim()); } public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain)throws IOException,ServletException{ if(enabled||characterEncoding !=null){ request.setCharacterEncoding(characterEncoding); response.setCharacterEncoding(characterEncoding); } response.getWriter().println(request.getParameter("username")); chain.doFilter(request, response); //执行下一个Filter } public void destroy(){ characterEncoding=null; //销毁时清空资源 } }
web.xml配置文件:
<filter> <filter-name>ForCharacterFilter</filter-name> <filter-class>cn.edu.bzu.ForCharacterFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>using</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>ForCharacterFilter</filter-name> <url-pattern>/cn.edu.bzu/*</url-pattern> </filter-mapping>
注意:
页面编码方式与Filter编码方式要一致。如果使用get方式提交表单,还需要修改Tomcat里面的配置文件
conf/server.xml
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="ISO-8859-1" useBodyEncodingForURI="true" />
就是设定它的默认编码集。
上面是使用过滤器的方式处理乱码:有时候这种方法可能会失效
下面是使用struts中处理乱码:
中文乱码,首先要区分是页面乱码、action乱码,还是数据库乱码。大致的原理是java使用unicode编码– >window使用gbk(gb2312的扩展集)–mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了 ^_^。解决方法如下:
<%@ page contentType=”text/html; charset=UTF-8″%> <%@ page pageEncoding=”UTF-8″ %> |
1.1 在jsp页面设定字符编码。这边有必有说明的是如果是jsp+java bean+servlet的方案,中文乱码很好解决,统一设成gb2312就可以了。
struts.devMode=false struts.enable.DynamicMethodInvocation=true struts.i18n.reload=true struts.ui.theme=simple struts.locale=zh_CN struts.serve.static.browserCache=false |
其中locale、encoding就是字符集的设定了。
3. 在web.xml加个filter
<!– zh-cn encoding –> <filter> <filter-name>struts-cleanup</filter-name> <filter-class> org.apache.struts2.dispatcher.ActionContextCleanUp </filter-class> </filter> <filter-mapping> <filter-name>struts-cleanup</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> |
跟上述方法,类似还有在action中设定字符编符.
HttpServletResponse response = null; response = ServletActionContext.getResponse(); request.setCharacterEncoding(”utf-8″); response.setContentType(”text/html;charset=utf-8″); |
通过上述方法,基本就可以搞定中文乱码的问题了。当然,也有例外(如web server的版本/数据库的版本等等)。象在我的一个项目碰到一个中文乱码,tomcate5.5是会乱码的,而在tomcate6中就不会。这边就涉及到tomcate connector字符的设置了。
<Connector port=”80″ maxHttpHeaderSize=”8192″ maxThreads=”150″ minSpareThreads=”25″ maxSpareThreads=”75″ enableLookups=”false” redirectPort=”8443″ acceptCount=”100″ connectionTimeout=”20000″ disableUploadTimeout=”true” URIEncoding=”GBK” /> |
——————————————————————–
后记之一:在使用struts2时,仍是遇到一种乱码。后来调试才发现,struts2的web.xml配置是有顺序的 。
在web.xml中EncodingFilter的位置应该在Struts2的FilterDispatcher之前,因为要先调整字符集,然后进入Action。
按照Struts2的API,filter的顺序是
struts-cleanup filter
SiteMesh filter
FilterDispatcher
——————————————————————–
后记之二:这个方法是下下策了,只有在前面的方法都无效时才使用。
在action中直接使用request.getParameter()时;还是出现乱码。原因分析如下:
1、getParameter()是有带字符参数的。例:
String s = (String)request.getParameter(”txt”).getBytes(”iso-8859-1 “);
2、String也可以带有字符参数。
String (byte[] bytes, String charsetName)
构造一个新的 String ,方法是使用指定的字符集解码指定的字节数组。
例:String s = new String(”中文”,”utf-8″);
3、综合上述两点,编写一个类来完成此项任务
public class ConvertCharacter{ public String Convert(String s){ String result; byte[] temp ; try{ temp = s.getBytes(”iso-8859-1″); result = new String(temp,”utf-8″); } return result; } } |
=====================================================
希望可以借鉴……