Hibernate неправильно кодирует при сохранении объектов [UTF-8]

Я столкнулся с проблемой кодирования UTF-8 при сохранении объектов моей модели. В турецком языке «ı» — это буква. Также есть некоторые другие турецкие символы, которые включены в кодировку UTF-8. Пока я сохраняю свои объекты модели, все символы 'ı' сохраняются как '?' в БД. Я использую MySQL 5.5 в 64-разрядной ОС Ubuntu Linux. Также я уже установил для свойства кодирования соединения hibernate и 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>

person talha06    schedule 01.08.2012    source источник


Ответы (3)


Попробуйте установить кодировку в источнике данных

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

Также вы уверены, что ввод из форм правильно закодирован? Используете ли вы фильтр в своем весеннем приложении? Запустите приложение в режиме отладки и проверьте поля объекта модели перед сохранением.

Фильтр должен быть размещен в вашем файле 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>
person pawelccb    schedule 02.08.2012
comment
После того, как вы попробовали все настройки Hibernate и MySQL, этот подход к фильтру сработал. Благодарность! - person Hudson Pena Magalhães; 11.11.2013
comment
‹param-value›UTF8‹/param-value› должно быть ‹param-value›UTF-8‹/param-value› (дефис пропущен) - person Sergiu; 02.04.2015
comment
это не работает для базы данных postgreSQL. Какие шаги я должен предпринять для базы данных postgreSQL? См. мой вопрос здесь stackoverflow.com/questions/33604379/ - person prem30488; 09.11.2015

Если вы добавили

?characterEncoding=UTF-8

следовательно, в строку подключения (после того, как база данных и таблицы уже созданы), вам необходимо заново создать базу данных. На самом деле в моем случае я воссоздал свою БД с помощью:

СОЗДАТЬ БАЗУ ДАННЫХ dbname НАБОР СИМВОЛОВ utf8 COLLATE utf8_general_ci;

OR

изменить базу данных my_database кодировку по умолчанию utf8 сопоставить utf8_general_ci;

Обратите внимание, что я использовал кириллические строки.

person a.valchev    schedule 02.06.2015

Проверьте, какие данные хранятся в вашем компоненте. Как заполняется ваш bean-компонент? Через пользовательский ввод? Если да, то вам также придется написать кодировку на этой странице как UTF-8 и изменить параметры запроса и ответа на UTF-8.

person Ankit    schedule 01.08.2012