13

在持久化我的模型对象时,我面临着 UTF-8 编码问题。在土耳其语中,“ ı ”是一个字母。UTF-8 编码中还包含一些其他土耳其语字符。当我坚持我的模型对象时,所有 ' '字符都坚持为 ' ? ' 到数据库。我在 Ubuntu Linux 64-bit OS 上使用 MySQL 5.5。此外,我也已经将休眠和 c3p0 连接编码属性设置为 UTF-8。当我调试时,来自客户端的数据是真实的。

这是我的配置,如果有人可以帮助我,我会很高兴。

提前致谢。


春季和休眠配置

    <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>
4

3 回答 3

31

尝试在数据源中设置编码

 <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>
于 2012-08-02T07:16:30.967 回答
1

如果您已添加

?characterEncoding=UTF-8

因此,连接字符串的参数(在创建数据库和表之后),您需要重新创建数据库。实际上,在我的情况下,我重新创建了我的数据库:

CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;

或者

alter database my_database default charset utf8 collat​​e utf8_general_ci;

请注意,我使用的是西里尔字符串。

于 2015-06-02T13:37:11.033 回答
0

检查 bean 中存储的数据是什么。你的 bean 是如何填充的?,是通过用户输入吗?,如果是,那么你将不得不在该页面中将编码写为 UTF-8,并将你的请求和响应参数更改为 UTF-8

于 2012-08-01T12:23:05.180 回答