8

簡単な質問があります。@Ressourceまたは@Autowiredを介して依存性注入をHibernateEventlistenerに追加することは可能ですか?

entitymanagerfactoryの構成を示します。

<bean id="entityManagerFactory" class="org.hibernate.ejb.EntityManagerFactoryImpl">
    <qualifier value="entityManagerFactory" />
    <constructor-arg>
        <bean
            class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
            <property name="persistenceUnitManager">
                <bean
                    class="org.springframework.orm.jpa.persistenceunit.DefaultPersistenceUnitManagerr">
                    <property name="defaultDataSource" ref="dataSource" />
                </bean>
            </property>
            <property name="dataSource" ref="dataSource" />
            <property name="persistenceUnitName" value="mis" />
            <property name="persistenceProviderClass" value="org.hibernate.ejb.HibernatePersistence" />
            <property name="jpaProperties" ref="jpa.properties" />
            <property name="jpaDialect" ref="jpaDialect" />
            <property name="jpaVendorAdapter">
                <bean
                    class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                    <property name="generateDdl" value="true" />
                    <property name="database">
                        <util:constant
                            static-field="org.springframework.orm.jpa.vendor.Database.POSTGRESQL" />
                    </property>
                    <property name="showSql" value="true" />
                </bean>
            </property>

        </bean>
    </constructor-arg>
</bean>

現時点では、jpa.propertiesを介してリスナーを登録しています。

hibernate.ejb.event.load=com.example.hibernate.events.LoadEvent

しかし、この場合、リスナーにスプリングインジェクションはありません。解決策を見つけましたが、これはentitymanagerではなくsessionFactoryを使用します。または、コンテキストでsessionfactoryを変更できますか?うまくいけば、誰かがこの問題に対処するための素晴らしいアイデアや解決策を持っています!

本当にありがとう!

4

1 に答える 1

16

SessionFactoryを使用した場合、これは構成になります。

<bean id="mySessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <!-- Stripped other stuff -->
    <property name="eventListeners">
        <map>
            <entry key="pre-load">
                <bean class="com.mycompany.MyCustomHibernateEventListener1" />
            </entry>
            <entry key="pre-persist">
                <bean class="com.mycompany.MyCustomHibernateEventListener2" />
            </entry>
        </map>
    </property>
</bean>

ただし、JPAを使用しているため、このスレッドで概説されているようにAOPを使用する必要があります。

またはあなたはすることができます

  1. ApplicationContextをThreadLocalまたはカスタムホルダークラスに格納し、静的メソッドを介して公開します
  2. 次のようなリスナーの基本クラスがあります。

基本クラス:

public abstract class ListenerBase{

    protected void wireMe(){
        ApplicationContext ctx = ContextHelper.getCurrentApplicationContext();
        ctx.getAutowireCapableBeanFactory().autowireBean(this);
    }

}

次に、lifycycleメソッドでwireMe()最初に呼び出します。


アップデート:

のサンプル実装は次のContextHelperとおりです。

public final class ContextHelper implements ApplicationContextAware{

    private static final ContextHelper INSTANCE = new ContextHelper();
    private ApplicationContext applicationContext;

    @Override
    public void setApplicationContext(final ApplicationContext applicationContext){
        this.applicationContext = applicationContext;
    }

    public static ApplicationContext getCurrentApplicationContext(){
        return INSTANCE.applicationContext;
    };

    public static ContextHelper getInstance(){
        return INSTANCE;
    }

    private ContextHelper(){
    }

}

次のように、SpringBean構成に配線します。

<bean class="com.mycompany.ContextHelper" factory-method="getInstance" />
于 2010-11-10T11:43:10.183 に答える