モデルオブジェクトを永続化するときに、UTF-8エンコーディングの問題に直面しています。トルコ語では「ı」は文字です。また、UTF-8エンコーディングに含まれている他のトルコ文字もいくつかあります。モデルオブジェクトを永続化する間、すべての 'ı'文字は '?'としてDBに永続化されます。私はbuntu Linux64ビットOS上のMySQL5.5を使用しています。また、hibernateとc3p0の接続エンコーディングプロパティもUTF-8に設定しました。私がデバッグするとき、データはクライアントから来ていますが本当です。
これが私の設定です。誰かが私を助けてくれたらとても嬉しいです。
前もって感謝します。
Spring&Hibernate Config
<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>
データソースでエンコーディングを設定してみてください
<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>
追加した場合
?characterEncoding = UTF-8
したがって、接続文字列へのパラメータ(データベースとテーブルがすでに作成された後)では、データベースを再作成する必要があります。実際、私の場合、次のようにデータベースを再作成しました。
CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;
OR
データベースの変更my_databaseデフォルトの文字セットutf8照合utf8_general_ci;
キリル文字を使用していたことに注意してください。
Beanに保存されているデータを確認してください。 Beanはどのように入力されますか?ユーザー入力によるものですか?はいの場合は、そのページにUTF-8としてエンコードを記述し、要求と応答のパラメーターをUTF-8に変更する必要があります。