Java Web项目表单数据存入数据库中文乱码解决

时间:2022-07-22 06:39:17

题记:第一篇博客,编辑器的很多功能还不熟悉,粗略写写,可能的看官们请见谅。

背景:用Struts、Spring、Hibernate整合一个小项目,有关编码的设置如下:

1、JSP页面的pageEncoding设置没问题,charset设置成UTF-8,form表单为get方式

2、Struts配置时没有显性设置常量struts.i18n.encoding,不设置则默认为UTF-8

3、MySQL数据库建库时设置了UTF-8编码方式

4、ApplicationContext.xml中jdbcUrl设置时在数据库名后加了"?useUnicode=true&characterEncoding=utf8"

其他关于编码的设置应该是没有了。

问题:表单提交中文数据并保存到数据库后显示乱码。

分析:自从Tomcat5.x开始,GET和POST方法提交的信息,tomcat采用了不同的方式来处理编码,对于POST请求,Tomcat会仍然使用request.setCharacterEncoding方法所设置的编码(也即Struts的struts.i18n.encoding的值)来处理,如果未设置,则使用iso-8859-1编码。而GET请求则不同,Tomcat对于GET请求并不会考虑使用request.setCharacterEncoding方法设置的编码,而会永远使用iso-8859-1编码。

解决:

第一种方式:把表单由get方式改为post方式。

第二种方式:在servlet中获取请求数据时用类似String s = new String(request.getParameter("s").getBytes("ISO-8859-1"), "UTF-8") 的方式,如果是SSH项目,可写一个拦截器进行类似处理。

第三种方式:(试了似乎不行,也可能是我赶时间没弄仔细)在tomacat的server.xml文件中对URIEncoding进行设置。

End