cdi请注入entitymanager,始终是nullpointer。以下配置:
的persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence 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_1_0.xsd"
version="1.0">
<persistence-unit name="tutoroo" transaction-type="JTA">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>java:/tutoroo</jta-data-source>
<properties>
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="false" />
<property name="hibernate.hbm2ddl.auto" value="create-drop" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
</properties>
</persistence-unit>
</persistence>
public class ProdutorEntityManager implements Serializable {
private EntityManagerFactory factory = Persistence.createEntityManagerFactory("tutoroo");
//private EntityManager entityManager = factory.createEntityManager();
@Produces
@PersistenceContext
@RequestScoped
public EntityManager criaEntityManager(){
return factory.createEntityManager();
}
public void dispose(@Disposes EntityManager em) {
em.close();
}
}
public class UsuarioDaoImp implements UsuarioDao {
@Inject
private EntityManager manager;
public void salvar(Usuario usuario) {
manager.persist(usuario);
}
}
当我调试EntityManager UsuarioDaoImp
类时,会发生以下异常:com.sun.jdi.InvocationException发生了调用方法。
我不知道我做错了什么。有人可以帮忙吗?
服务器是:jboss-as-7.1.1
答案 0 :(得分:4)
首先,不要在应用服务器中自己创建持久性单元,而是让服务器为您注入。
这就是为什么,来自JavaDocs:
Persistence类也可以在Java EE容器环境中使用;但是,在容器环境中不需要支持Java SE引导API。
不确定jbos-as-7的行为方式,但由于失去JTA支持等原因,通常不鼓励这样做。
为简单起见,我假设您的应用程序中只有一个持久性单元。如果您需要具有多个持久性单元的应用程序的示例,请询问并编辑。
只需在任何 CDI托管bean中使用实体管理器:
public class CDIBean {
// the container injects it
@PersistenceContext
private EntityManager em;
// just use it
public void someMethod(Entity someEntity) {
this.em.persist(someEntity);
}
}
这就是它的全部内容。
然而,在许多例子中,出于各种原因宣布了生产者/处置者的组合。我敢打赌,这就是混乱的来源。一些用例:
允许您使用@Inject EntityManger em;
代替@PersistenceContext EntityManager em;
// to make it available for injection using @Inject
public class CDIProducer {
// again, the container injects it
@PersistenceContext
private EntityManager em;
// this will have the default dependent scope
@Produces
public EntityManager em() {
return em;
}
public void dispose(@Disposes EntityManager em) {
em.close();
}
}
// to use it
public class CDIBean {
@Inject
private EntityManager em;
// just use it
public void someMethod(Entity someEntity) {
this.em.persist(someEntity);
}
}
或将实体管理器绑定到特定范围。
// to make it available for injection using @Inject, and bind it to the @RequestScope
public class CDIProducer {
// again, the container injects it
@PersistenceContext
private EntityManager em;
// this will be in the request scope
@Produces
@RequestScoped
public EntityManager em() {
return em;
}
public void dispose(@Disposes @RequestScoped EntityManager em) {
em.close();
}
}
// to use it
public class CDIBean {
@Inject
private EntityManager em;
// just use it
public void someMethod(Entity someEntity) {
this.em.persist(someEntity);
}
}
最后,上面的方法生成器可以转换为字段生成器。这相当于最后一个例子:
// to make it available for injection using @Inject, and bind it to the @RequestScope
public class CDIProducer {
@PersistenceContext
@Produces
@RequestScoped
private EntityManager em;
public void dispose(@Disposes @RequestScoped EntityManager em) {
em.close();
}
}
答案 1 :(得分:0)
我认为@RequestScoped不允许作为参数注入。