EntityManagerFactory не внедряется с помощью @PersistenceUnit

Я новичок в Java. У меня проблемы с настройкой модуля персистентности с использованием транзакций JTA. Мне нужно использовать базу данных PostgreSQL, которая уже определена, настроена и заполнена. Используя NetBeans, я создал persistance.xml а также glassfish-resources.xml как пара:

<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
    <persistence-unit name="WellWatcherPU" transaction-type="JTA">
         <jta-data-source>WellWatcherDB</jta-data-source>
         <exclude-unlisted-classes>false</exclude-unlisted-classes>
         <properties>
             <property name="eclipselink.logging.logger" value="org.eclipse.persistence.logging.DefaultSessionLog"/>
             <property name="eclipselink.logging.level" value="FINE"/>
         </properties>
     </persistence-unit>
</persistence>

а также

<resources>
    <jdbc-connection-pool allow-non-component-callers="false" associate-with-thread="false" connection-creation-retry-attempts="0" connection-creation-retry-interval-in-seconds="10" connection-leak-reclaim="false" connection-leak-timeout-in-seconds="0" connection-validation-method="auto-commit" datasource-classname="org.postgresql.ds.PGSimpleDataSource" fail-all-connections="false" idle-timeout-in-seconds="300" is-connection-validation-required="false" is-isolation-level-guaranteed="true" lazy-connection-association="false" lazy-connection-enlistment="false" match-connections="false" max-connection-usage-count="0" max-pool-size="32" max-wait-time-in-millis="60000" name="post-gre-sql_geowellex_geowellexPool" non-transactional-connections="false" pool-resize-quantity="2" res-type="javax.sql.DataSource" statement-timeout-in-seconds="-1" steady-pool-size="8" validate-atmost-once-period-in-seconds="0" wrap-jdbc-objects="false">
        <property name="serverName" value="localhost"/>
        <property name="portNumber" value="5432"/>
        <property name="databaseName" value="DBNAME"/>
        <property name="User" value="USER"/>
        <property name="Password" value="PASSWORD"/>
        <property name="URL" value="jdbc:postgresql://localhost:5432/DBNAME"/>
        <property name="driverClass" value="org.postgresql.Driver"/>
    </jdbc-connection-pool>
    <jdbc-resource enabled="true" jndi-name="WellWatcherDB" object-type="user" pool-name="post-gre-sql_geowellex_geowellexPool"/>
</resources>

И вот как я получаю EntityManagerFactory и EntityManager (как используется в примере с NetBeans)

public class EUserDao {

@Resource
private UserTransaction utx = null;
@PersistenceUnit(unitName = "WellWatcherPU")
private EntityManagerFactory emf = null;

public EntityManager getEntityManager() {
    return emf.createEntityManager();  <-------- NullPointerException here
}

public EUser getOne(long userId){
    EntityManager em = getEntityManager();
    try {
        return em.find(EUser.class, userId);
    } finally {
        em.close();
    }
}

РЕДАКТИРОВАТЬ:

А вот мой журнал развертывания Glassfish:

Информация: [EL Config]: 2012-05-10 12:01:13.534- ServerSession(2017352940)- Соединение (1901223982)- Нить (Нить [admin-thread-pool-4848(5),5,grizzly- ядро])- подключение (DatabaseLogin(платформа => имя пользователя DatabasePlatform => "" соединитель => имя источника данных JNDIConnector => ноль))

Информация: [EL Config]: 2012-05-10 12:01:13.534- ServerSession(2017352940)- Соединение (1462281761)- Нить (Нить [admin-thread-pool-4848(5),5,grizzly-kernel])- Подключено: jdbc:postgresql://localhost:5432/geowellex?loginTimeout=0&prepareThreshold=0 Пользователь: geowellex База данных: PostgreSQL Версия: 9.1.3 Драйвер: собственный драйвер PostgreSQL Версия: PostgreSQL 8.3 JDBC3 с SSL (сборка 603)

Информация: [EL Config]: 2012-05-10 12:01:13.534- ServerSession(2017352940)- Соединение (766700859)- Нить (Нить [admin-thread-pool-4848(5),5,grizzly- ядро])- подключение (DatabaseLogin(платформа => имя пользователя PostgreSQLPlatform => "" соединитель => имя источника данных JNDIConnector => ноль))

В чем дело?

2 ответа

Решение

Скорее всего, проблема в том, что ваш EUserDao - это обычный класс. Инъекция работает только для контейнеров управляемых классов. Аннотации, такие как @PersistenceUnit и @Resource, не обрабатываются для обычных классов.

Следующие типы классов являются классами, управляемыми контейнером (и в них может использоваться @PersistenceUnit):

  • Сервлет: сервлеты, фильтры сервлетов, слушатели событий
  • JSP: обработчики тегов, слушатели событий библиотеки тегов
  • JSF: управляемые бобы
  • JAX-WS: конечные точки службы, обработчики
  • EJB: бобы, перехватчики
  • Управляемые бобы: управляемые бобы
  • CDI: управляемые компоненты в стиле CDI, декораторы
  • Платформа Java EE: основной класс (статический), обработчик обратного вызова для входа

Я вижу, что в вашем коде объявить:

private EntityManagerFactory emf = null;

но никогда не создавай... как это

emf = Persistence.createEntityManagerFactory("WellWatcherPU");

Вот почему вы получаете исключение нулевого указателя при использовании объекта!

public EntityManager getEntityManager() {
    return emf.createEntityManager();  <-------- NullPointerException here
}
Другие вопросы по тегам