Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Hibernate kodiert beim Persistieren von Objekten falsch [UTF-8]

Versuchen Sie, die Codierung in der Datenquelle einzustellen

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

Sind Sie auch sicher, dass die Eingabe von Formularen richtig codiert ist? Verwenden Sie Filter in Ihrer Federanwendung? Führen Sie die Anwendung im Debug-Modus aus und überprüfen Sie die Felder Ihres Modellobjekts, bevor Sie sie beibehalten.

Der Filter sollte in Ihrer web.xml-Datei platziert werden:

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