Hibernate 在持久化对象时编码错误 [UTF-8]
Posted
技术标签:
【中文标题】Hibernate 在持久化对象时编码错误 [UTF-8]【英文标题】:Hibernate encodes wrong while persisting objects [UTF-8] 【发布时间】:2012-07-30 06:44:47 【问题描述】:我在保留模型对象时遇到了 UTF-8 编码问题。在土耳其语中,“ı”是一个字母。 UTF-8 编码中还包含一些其他土耳其语字符。当我持久化我的模型对象时,所有 'ı' 字符都作为 '?' 持久化到 DB。我在 Ubuntu Linux 64 位操作系统上使用 MySQL 5.5。此外,我也已经将休眠和 c3p0 连接编码属性设置为 UTF-8。当我调试时,来自客户端的数据是真实的。
这是我的配置,如果有人可以帮助我,我会很高兴。
提前致谢。
Spring & Hibernate 配置
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource"><ref local="dataSource"/></property>
<property name="packagesToScan" value="com.tk.dms.model" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.use_sql_comments">true</prop>
<prop key="hibernate.format_sql">false</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.generate_statistics">true</prop>
<prop key="hibernate.dialect">org.hibernate.dialect.mysql5InnoDBDialect</prop>
<prop key="hibernate.connection.characterEncoding">UTF-8</prop>
<prop key="hibernate.connection.useUnicode">true</prop>
<!-- c3p0 properties -->
<prop key="hibernate.c3p0.min_size">2</prop>
<prop key="hibernate.c3p0.max_size">50</prop>
<prop key="hibernate.c3p0.maxPoolSize">50</prop>
<prop key="hibernate.c3p0.minPoolSize">2</prop>
<prop key="hibernate.c3p0.initialPoolSize">2</prop>
<prop key="hibernate.c3p0.timeout">300</prop>
<prop key="hibernate.c3p0.max_statements">50</prop>
</props>
</property>
</bean>
【问题讨论】:
【参考方案1】:检查 bean 中存储的数据是什么。您的 bean 是如何填充的?是通过用户输入吗?如果是,那么您将不得不在该页面中编写编码为 UTF-8 以及将您的请求和响应参数更改为 UTF-8
【讨论】:
【参考方案2】:尝试在数据源中设置编码
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://127.0.0.1:3306/databaseName?characterEncoding=UTF-8</value>
</property>
<property name="username">
<value>?</value>
</property>
</bean>
您还确定来自表单的输入已正确编码吗?您在 Spring 应用程序中使用过滤器吗?在调试模式下运行应用程序并在持久化之前检查模型对象的字段。
过滤器应该放在您的 web.xml 文件中:
<filter>
<filter-name>SetCharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>SetCharacterEncodingFilter</filter-name>
<url-pattern>*</url-pattern>
</filter-mapping>
【讨论】:
在尝试了所有的 Hibernate 和 MySQL 配置之后,该过滤方法奏效了。谢谢!如果你已经添加了
?characterEncoding=UTF-8
连接字符串的参数因此(在已经创建数据库和表之后),您需要重新创建数据库。实际上在我的情况下,我重新创建了我的数据库:
CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;
或
alter database my_database default charset utf8 collate utf8_general_ci;
请注意,我使用的是西里尔字符串。
【讨论】:
以上是关于Hibernate 在持久化对象时编码错误 [UTF-8]的主要内容,如果未能解决你的问题,请参考以下文章