Hibernate кодирует ошибки при сохранении объектов [UTF-8]
Я столкнулся с проблемой кодирования UTF-8, сохраняя мои объекты модели. На турецком языке ı - это письмо. Также есть некоторые другие турецкие символы, которые включены в кодировку UTF-8. Пока я сохраняю свои объекты модели, все символы ı сохраняются как "?" в DB. Я использую 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>
Ответы
Ответ 1
Попробуйте установить кодировку в источнике данных
<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>
Ответ 2
Если вы добавили
? CharacterEncoding = UTF-8
для строки подключения, следовательно (после того, как db и таблицы уже созданы), вам нужно воссоздать свою базу данных. На самом деле, в моем случае я воссоздал свой db с помощью:
CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;
ИЛИ
изменить базу данных my_database по умолчанию charset utf8 collate utf8_general_ci;
Обратите внимание, что я использовал кириллические строки.
Ответ 3
Проверьте, какие данные хранятся в bean. Как ваш bean заполняется?, через пользовательский ввод?, если да, то вам придется писать кодировку на этой странице как UTF-8, а также изменить свой параметр запроса и ответа на UTF-8