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

本文介绍了一种在Spring+Hibernate+Struts2框架下解决中文乱码的方法。通过调整Spring中数据库连接的字符集参数,确保了从持久层到数据库传输的中文数据正确无误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       今天用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服务器和数据库的编码问题,同样要注意持久化层数据传输的编码问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值