zoukankan      html  css  js  c++  java
  • spring+hibernate+struts2应用mysql数据库乱码问题

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

    hxzon:
    在spring配置文件里url末尾添加
    ?characterEncoding=gbk,没有变化。
    在struts配置文件里写
    <constant name="struts.i18n.encoding" value="UTF-8" />
    还是乱码。
    最后发现jsp页面里没改过来。
    改为<%@ page language="java" pageEncoding="UTF-8"%>
    不再乱码,而且去掉spring里写的那一句,也没乱码。
    补充:spring中应该用转义字符才行。
    <property name="url"
    value="jdbc:mysql://localhost/mysql?useUnicode=true&amp;characterEncoding=gbk"/>
    数据库默认latin1,数据库建表默认utf8,连接使用gbk,中文不再乱码。
    ---相关资料-----------------------------------
    今天用spring+hibernate+struts2写了一个简单的示例程序,使用spring来管理hibernate处理数据,整合了struts2,用了很长时间的webwork,使用struts2也还算是顺手,显示测试数据很顺利,当开始测试录入数据功能时,录入汉字发生了问题,录入的汉字全部成了乱码。

    最开始认为是在tomcat中中文传输出现了问题,加入了中文过滤器,但问题没有解决,忽然想到了在struts2的属性文件中已经设置了编码为gbk:
    struts.properties
    struts.i18n.encoding=GBK
    struts.objectFactory=spring
    应该不是在传输过程出的问题,在后台输入传入Action和Dao的数据,也全部能正常显示。
    然后怀疑是mysql的设置问题,查找设置mysql的数据库编码设置方法,在设置后仍没有解决问题。
    直接在mysql中执行Insert into user ('nam') values('汉字'),mysql执行后数据显示正常,说明数据库的编码也正确。
    郁闷了,到底问题处在哪里?在执行hibernateTemplate的save()方法之前,没有出现中文乱码问题,在数据库这方面也测试没有中文乱码问题,只有在hibernate持久化层这里的问题了。
    查找持久化层传输数据到数据库服务器出现乱码的问题,终于找到了问题:
    hibernate持久化层在传输过程中未设置编码格式,这样在传输数据到数据库服务器后已经是乱码了,在oracle和sqlserver里没有出现传输乱码问题,所以没有想到会使这里的问题。
    修改spring中关于数据源的配置参数:
    数据库链接方式:

    jdbc:mysql://localhost:3306/springexample?characterEncoding=utf-8

    在执行数据录入后,终于中文显示正常了。
    在应用hibernate管理mysql数据库是不仅要注意web服务器和数据库的编码问题,同样要注意持久化层数据传输的编码问题。

  • 相关阅读:
    错题记录——关于Java中private的用法(类与封装)
    深度学习-人脸识别-数据集和制作
    UE4使用经验记录
    pycharm 一直索引或索引过大占用系统盘问题
    深度学习portoch笔记_概念随笔
    mysql 找不到请求的 .Net Framework Data Provider。可能没有安装。
    halcon崩溃/异常信号11 后文件临时存储路径
    halcon 错误记录
    visual studio 2012 C#exe嵌入到子窗口,程序退出后子exe文件仍然被占用
    文件操作
  • 原文地址:https://www.cnblogs.com/leehongee/p/2711994.html
Copyright © 2011-2022 走看看