Создание слоя сопротивления с пружиной / спящим - PullRequest
1 голос
/ 11 октября 2011

Я пытаюсь создать проект персистентности, чтобы его можно было использовать в других проектах, над которыми я работаю. Т.е. он будет использоваться веб-сервисом / проектом Spring mvc и автономным jar, который выполняет некоторую обработку файлов.

Раньше я использовал hibernate с spring mvc, но никогда как автономный исполняемый java jar, поэтому у меня все настроено и работает (контекст приложения):

<?xml version="1.0" encoding="UTF-8"?>
<beans  xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xmlns:context="http://www.springframework.org/schema/context"
        xsi:schemaLocation="
   http://www.springframework.org/schema/beans 
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
   http://www.springframework.org/schema/tx 
   http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

    <!-- Enable annotation style of managing transactions -->
    <tx:annotation-driven transaction-manager="transactionManager" />

    <!-- Root Context: defines shared resources visible to all other web components -->

    <!-- HIBERNATE -->
    <bean id="propertyConfigurer"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location" value="classpath:spring.properties" />
    </bean>

    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
    <property name="driverClass" value="${jdbc.driverClassName}" />
    <property name="jdbcUrl" value="${jdbc.databaseurl}" />
    <property name="user" value="${jdbc.username}" />
    <property name="password" value="${jdbc.password}" />
    <property name="acquireIncrement" value="5" />
    <property name="idleConnectionTestPeriod" value="60"/>
    <property name="maxPoolSize" value="100"/>
    <property name="maxStatements" value="50"/>
    <property name="minPoolSize" value="10"/>
    </bean>

    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="mappingResources">
            <list>      <value>com/project/utility/persistence/mapping/TestProp.hbm.xml</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${jdbc.dialect}</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
    </bean>


    <bean id="transactionManager"
        class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

    <!-- END HIBERNATE -->
</beans>

Когда я тестирую его из основного класса, все выглядит нормально с отображением / зависимостями:

public static void main(String[] args) {
        ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("appCtx.xml");
    }

Далее я хочу создать несколько дао-классов, которые будут получать некоторые данные, и я бы создал вышеупомянутый интерфейс, чтобы его можно было повторно использовать как веб-сервисом, так и инструментом обработки в качестве jar (зависимости maven).

Чтобы построить классы dao, мне нужно, чтобы sessionFactory всегда был! = Null. Как мне это сделать?

Ответы [ 2 ]

1 голос
/ 11 октября 2011
@Repository
public class MyDAO {

    @Autowired
    private SessionFactory sessionFactory;

    // ...
}

и добавьте компонент MyDAO в контекстный XML-файл или просто добавьте в этот файл следующие строки:

<context:annotation-config />
<context:component-scan base-package="one.of.the.parent.packages.of.your.dao" />
1 голос
/ 11 октября 2011

Есть много подходов к этому. Одним из решений, которое я использую, является использование аннотации javax.persistence.PersistenceContext. Spring будет учитывать эту аннотацию и вставлять прокси в локальный поток EntityManager. При условии, что Spring создает ваш DAO, это позволяет получить доступ к менеджеру сущностей из вашего DAO.

public class DAO {

  private EntityManager entityManager;
  @PersistenceContext
  public void setEntityManager(EntityManager entityManager) {
    this.entityManager = entityManager;
  }

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...