在学习struts中,遇到了中文乱码问题,解决方法整理如下:
使用get方法时:需要修改 $TOMCAT/conf/server.xml部署文件,改变web容器请求数据的编码格式(对post请求方式无效)
,在connectior属性中添加URIEncoding="GBK"即可,具体如下:
<Connector port="8080" maxHttpHeaderSize="8192"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK" />
注意:struts中过滤器、重写formBean里面reset方法、重写action里的processPreprocessor()方法 均对get请求无效
使用post方法时,有2种方法可选
方法1:在Struts1.11版本之后,ActionServlet不再处理所有请求,而是把大部分请求抛给了RequestProcessor类,作为ActionServlet的助手.在它的process()方法中会调用16个方法.可以声明一个MyProRequestProcessor类继承RequestProcessor类,重写某个方法,添加编码的代码。如重写processPreprocessor()方法,这个方法在源码中没有任何逻辑操作,只是返回一个true还可以重写processContent(HttpServletRequest,HttpServletResponse)等方法,但是推荐还是重写上面的processPreprocess方法,因为里面没有任何逻辑代码,所以你不用担心会破环原来的处理过程。
import java.io.UnsupportedEncodingException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class RequestProcessor extends org.apache.struts.action.RequestProcessor {
/*
* 重写processPreprocess方法
*/
protected boolean processPreprocess(HttpServletRequest request,
HttpServletResponse response) {
try {
request.setCharacterEncoding("GBK");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return super.processPreprocess(request, response);
}
} 在struts-config.xml中,设定控制器如下:
<controller processorClass="com.test.util.MyProRequestProcessor"/>
注意:按照did设定的顺序来,<controller>标签要写在<action-mappings>之后。
方法2:设置过滤器,这个方法是用的最多也是最方便的、可将Struts servlet jsp中文乱码问题一网打尽。写一个实现了javax.servlet.Filter接口的类(CharacterEncodingFilter),此类可以在$TOMCAT/webapps/servlets-examples/WEB-INF/classes/filters找到,也可以自己写,源码如下:
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 CharacterEncodingFilter implements Filter {
private FilterConfig config = null;
private String encoding = "GBK";
public void destroy() {
this.config = null;
this.encoding = null;
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
request.setCharacterEncoding(encoding);
chain.doFilter(request, response);
}
public void init(FilterConfig config) throws ServletException {
this.config = config;
String s = config.getInitParameter("encoding");
if(s != null){
encoding = s;
}
}
}
在web.xml中部署这个过滤器
<filter>
<filter-name>EncodingFilter</filter-name>
<filter-class>com.bjsxt.drp.business.util.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>EncodingFilter </filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
最后千万要注意的是:你所设定的支持中文的编码一定要和页面的编码一致。否则一样是乱码!