13

モデル オブジェクトを保持しているときに、UTF-8 エンコーディングの問題に直面しています。トルコ語で「ı」は文字です。また、UTF-8 エンコーディングに含まれるトルコ語文字もいくつかあります。モデル オブジェクトを保持している間、すべての「ı」文字は「? 」として保持されます。'DB へ。Ubuntu Linux 64 ビット OS で MySQL 5.5を使用しています。また、すでに休止状態と c3p0 接続エンコーディング プロパティも UTF-8 に設定しています。デバッグすると、クライアントからのデータは true です。

これが私の設定です。誰かが私を助けてくれればとてもうれしいです。

前もって感謝します。


春と休止状態の構成

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

また、フォームからの入力が適切にエンコードされていると確信していますか? 春のアプリケーションでフィルターを使用しますか? アプリケーションをデバッグ モードで実行し、永続化する前にモデル オブジェクトのフィールドを確認します。

フィルターは 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

を追加した場合

?文字エンコーディング=UTF-8

パラメータを接続文字列に追加した結果 (db とテーブルが既に作成された後)、データベースを再作成する必要があります。実際、私の場合、次のようにデータベースを再作成しました:

CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;

また

データベース my_database デフォルトの文字セット utf8 を変更します utf8_general_ci を照合します。

キリル文字列を使用していたことに注意してください。

于 2015-06-02T13:37:11.033 に答える
0

Bean に格納されているデータを確認します。Bean はどのように設定されていますか? ユーザー入力によるものですか? はいの場合は、そのページにエンコーディングを UTF-8 として記述し、リクエストとレスポンスのパラメーターを UTF-8 に変更する必要があります。

于 2012-08-01T12:23:05.180 に答える