http://blog.csdn.net/hjw506848887/article/details/8966194
今天写项目时,突然遇到了struts2中表单提交的中文乱码问题,调了好久就是不知道答案。
下面的我的jsp页面:
- <form action="indexAction.action">
- <input name="dimName" type="text" />
- <br />
- <input name="submit" type="submit" />
- </form>
而传到indexAction的dimName参数却是一堆乱码,
我的struts.xml关于编码的有如下配置:
- <constant name="struts.i18n.encoding" value="UTF-8" />
首先我所有的网页统一用的是UTF-8。。。
正常来说是没问题的,但是我在indexAction中
- System.out.println(dimName);
打印出的结果却是一堆乱码,花了我好长时间,也许是我经验不足吧!后来才发现,我把上面的jsp页面改为:
- <form action="indexAction.action" method="post">
- <input name="dimName" type="text" />
- <br />
- <input name="submit" type="submit" />
- </form>
乱码竟然消失了!!!我无语啊,看来post和get的区别还在于乱码问题。
怎么解决呢???
小弟找了一个可行的方法:
如果的都是用的Post的话,一切都没有问题!什么都不用动。但是如果你是用的get,就去你的tomcat目录下的conf/server.xml中找到下面一段:
- <Connector port="8080" protocol="HTTP/1.1"
- connectionTimeout="20000"
- redirectPort="8443" URIEncoding="UTF-8"/>
本来的URLEncoding="UTF-8"是没有的,加上这一句话,就行了,下面是为什么这么做的原因:
<constant name="struts.i18n.encoding" value="UTF-8" />
表示把struts2设置为utf-8,相当于response.setCharacterEncoding("UTF-8"),对HTTP请求的数据进行编码,但是get请求的数据是直接在URL中,通过配置struts2配置为utf-8或CharacterEncodingFilter拦截器都不会对URL进行拦截并转换。对于很多人来说会觉得用 request.setCharacterEncoding("字符集")可以指定解码方式,其实是不可以的,当看了servlet的官方API说明有对此方法的解释:Overrides the name of the character encoding used in the body of this request. This method must be called prior to reading request parameters or reading input using getReader().可以看出对于get方法它是无能为力的。那么到底用什么编码方式解码数据的呢,这是tomcat的事情了,默认缺省用的是 iso-8859-1
所以出现了上面的配置方式。
当然了还的一种:
- new String(request.getParameter("name").getBytes("iso-8859-1"),"客户端指定的URL encode编码方式")
总之,对于post来说,乱码问题是很容易解决的,关键在于get,因为所有页面上的编码设置对于get方法是彻底无效的。