日期:2014-05-16  浏览次数:20456 次

修改spring+hibernate+struts2应用mysql数据库乱码问题

?????? 今天用spring+hibernate+struts2写了一个简单的示例程序,使用spring来管理hibernate处理数据,整合了struts2,用了很长时间的webwork,使用struts2也还算是顺手,显示测试数据很顺利,当开始测试录入数据功能时,录入汉字发生了问题,录入的汉字全部成了乱码。

???? 最开始认为是在tomcat中中文传输出现了问题,加入了中文过滤器,但问题没有解决,忽然想到了在struts2的属性文件中已经设置了编码为gbk:

struts.properties
  1. struts.i18n.encoding=GBK??
  2. struts.objectFactory=spring????

? 应该不是在传输过程出的问题,在后台输入传入Action和Dao的数据,也全部能正常显示。

? 然后怀疑是mysql的设置问题,查找设置mysql的数据库编码设置方法,在设置后仍没有解决问题。

? 直接在mysql中执行Insert into user ('nam') values('汉字'),mysql执行后数据显示正常,说明数据库的编码也正确。

? 郁闷了,到底问题处在哪里?在执行hibernateTemplate的save()方法之前,没有出现中文乱码问题,在数据库这方面也测试没有中文乱码问题,只有在hibernate持久化层这里的问题了。

??查找持久化层传输数据到数据库服务器出现乱码的问题,终于找到了问题:

? hibernate持久化层在传输过程中未设置编码格式,这样在传输数据到数据库服务器后已经是乱码了,在oracle和sqlserver里没有出现传输乱码问题,所以没有想到会使这里的问题。

? 修改spring中关于数据源的配置参数:

?

数据库链接方式:

? <property name="url">
???<value></value>jdbc:mysql://localhost:3306/springexample?characterEncoding=utf-8
??</property>

?

在执行数据录入后,终于中文显示正常了。

在应用hibernate管理mysql数据库是不仅要注意web服务器和数据库的编码问题,同样要注意持久化层数据传输的编码问题。

1 楼 wujiekangyun 2007-11-29  
谢谢,正好遇到相同的问题.
2 楼 wanghuan8086 2007-12-22  
这问题困我2天了,谢谢LZ
3 楼 capfjian 2008-06-05  
太感谢了,我也遇到相同问题,看了楼主的解释正的太好了
4 楼 六芒星の詛咒 2008-06-23  
为什么我的还是不行的呀~~~~~我在spring里的配置文件里设置好了呀,可是还是..
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="com.mysql.jdbc.Driver">
</property>
<property name="url" value="jdbc:mysql://localhost:3306/pala?characterEncoding=gbk"></property>
<property name="username" value="root"></property>
<property name="password" value="3348635"></property>
</bean>
5 楼 六芒星の詛咒 2008-06-23  
已经解决·~~哈哈·~~郁闷了一天多~终于搞定了·~
6 楼 raining_cn 2008-07-29  
我也是,郁闷一个下午。
7 楼 laupeng 2008-11-04  
说真的。太谢谢你了。
8 楼 liuwei1981 2008-11-07  
 
9 楼 Ethip 2008-11-07  
用Struts2,我也遇到过类似的问题
10 楼 whoamiaaaa 2011-12-06  
hibernate.properties里加入
useUnicode=true