今天用struts写了一个一段程序,是向数据库中插入一条记录,在表单提交是出现中文乱码问题,办法用的最多的是filter,可是这会占用比较多的系统资源,我的办法是自己写一个类这个类继承ActionServlet,就叫MyActionServlet,在这个类中覆盖process方法,代码如下:
你说这个方法是不是很巧妙啊!!!
可是,今天我的程序也是这样的,但还是出现了无情的乱码,网上很多人说这个办法在struts1里用是不行的,后来重新看了struts源码,才发现里面有段代码是这样的:
这是我才想起,通过表单提交的method不同,对应的处理乱码方法也不同
这种方法对于post提交的是有效的,而对于get方法提交需要用先还原,也就是用getBytes得到字节数据,然后用gbk编码构建一个新的字符串,代码如下:
public class MyActionServlet extends org.apache.struts.action.ActionServlet {
@Override
protected void process(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
request.setCharacterEncoding("GBK");
super.process(request, response);
}
}
你说这个方法是不是很巧妙啊!!!
可是,今天我的程序也是这样的,但还是出现了无情的乱码,网上很多人说这个办法在struts1里用是不行的,后来重新看了struts源码,才发现里面有段代码是这样的:
protected HttpServletRequest processMultipart(HttpServletRequest request) {
if (!"POST".equalsIgnoreCase(request.getMethod()))
return request;
String contentType = request.getContentType();
if (contentType != null
&& contentType.startsWith("multipart/form-data"))
return new MultipartRequestWrapper(request);
return request;
}
这是我才想起,通过表单提交的method不同,对应的处理乱码方法也不同
这种方法对于post提交的是有效的,而对于get方法提交需要用先还原,也就是用getBytes得到字节数据,然后用gbk编码构建一个新的字符串,代码如下:
String newStr=new String(oldStr.getBytes("ISO-8859-1"),"GBK");
就OK了