Hibernate接続Oracleデータベースの文字化けしの問題


最近、プロジェクトを作りました.フレーム型Struts+Spring+Hibernateフレームワークを使っています.以前このフレームワークで接続していたデータベースはすべてGBKコードセットで、今回接続したのはOracle AMERICAN_です.AMERICA.US 7 A SCIIコードは、これでプロジェクトが実行されてから文字化けして憂鬱になり、それぞれが自分でトランスコードを書くと、本当に疲れて煩わしいので、Hibernateでどのような方法で漢字コードを正常にするかを考えています.
何度も試して、達人を探して教えてもらうこととネット上の検索を経て、最後に1種の比較的に便利で実用的な方法を発見しました:
まず、デフォルトのタイプを置換するGBKStringを定義し、マッピングファイルでTYPEとして使用します.
例:
<property name="battrancode" column="battrancode" type="String" />

置換:

<property name="battrancode" column="battrancode" type="com.nl.tsp.dao.GBKString" />


 
GBKString.java 
Java   
package com.nl.tsp.dao;   
  
import java.io.Serializable;   
import java.io.UnsupportedEncodingException;   
import java.sql.PreparedStatement;   
import java.sql.ResultSet;   
import java.sql.SQLException;   
  
import oracle.jdbc.driver.OracleTypes;   
  
import org.apache.commons.lang.builder.HashCodeBuilder;   
import org.hibernate.HibernateException;   
import org.hibernate.usertype.UserType;   
  
/**  
 * @description  
 * @author Jason Tseng  
 *   
 */  
public class GBKString implements UserType {   
  
    public GBKString() {   
        super();   
    }   
  
    public int[] sqlTypes() {   
        return new int[] { OracleTypes.VARCHAR };   
    }   
  
    public Class returnedClass() {   
        return String.class;   
    }   
  
    public boolean equals(Object x, Object y) throws HibernateException {   
        return (x == y) || (x != null && y != null && (x.equals(y)));   
    }   
  
    public Object nullSafeGet(ResultSet rs, String[] names, Object owner) throws HibernateException,   
            SQLException {   
        String val = rs.getString(names[0]);   
        if (null == val) {   
            return null;   
        } else {   
            try {   
                val = new String(val.getBytes("iso-8859-1"), "GBK");   
            } catch (UnsupportedEncodingException e) {   
                throw new HibernateException(e.getMessage());   
            }   
            return val;   
        }   
    }   
  
    public void nullSafeSet(PreparedStatement st, Object value, int index) throws HibernateException,   
            SQLException {   
        if (value == null) {   
            st.setNull(index, OracleTypes.VARCHAR);   
        } else {   
            String val = (String)value;   
            try {   
                val = new String(val.getBytes("GBK"), "iso-8859-1");   
            } catch (UnsupportedEncodingException e) {   
                throw new HibernateException(e.getMessage());   
            }   
            st.setObject(index, val, OracleTypes.VARCHAR);   
        }   
    }   
  
    public Object deepCopy(Object value) throws HibernateException {   
        if (value == null)   
            return null;   
        return new String((String) value);   
    }   
  
    public boolean isMutable() {   
        return false;   
    }   
  
    public Object assemble(Serializable arg0, Object arg1) throws HibernateException {   
        // TODO Auto-generated method stub   
        return null;   
    }   
  
    public Serializable disassemble(Object arg0) throws HibernateException {   
        // TODO Auto-generated method stub   
        return null;   
    }   
  
    public int hashCode(Object arg0) throws HibernateException {   
        return HashCodeBuilder.reflectionHashCode(this);   
    }   
  
    public Object replace(Object arg0, Object arg1, Object arg2) throws HibernateException {   
        // TODO Auto-generated method stub   
        return null;   
    }   
}  

その後Web.xmlプロファイルでは,フィルタをGBKに設定することで問題なく,これが最も便利で実用的である.
これまで何度か試したことがありますが、例えばGBKStringというクラスではget時のみトランスコードし、set時に同時フィルタ設定iso-8859-1を回転させません.これもなんとか使えますが、Javaクラスでオブジェクトのsetメソッドを使うには、手作業で回る必要があります.