从Web服务EJB3会话bean调用EJB3会话bean,导致实体管理器为null

时间:2016-09-29 09:13:53

标签: java web-services ejb hibernate-entitymanager

好的我在这里有一个场景,我想要一个标准的解决方案,基本上我在服务器端公开了EJBsession3 bean作为我的webservice,他们进一步调用EJBsession3 bean来执行DAO方法。以下是示例代码。

//This is a EJB3 session bean and I am using container managed jta transactions 
@Stateless
public class datatypes implements datatypesRemote {

@PersistenceContext(unitName = "EJBtest")
EntityManager entityManager;


public List<Datatype> retrieveAllDatatypes(int targetSystemId,EntityManager ent)
        throws RuntimeException {
    String q = "SELECT oneDatatype from " + Datatype.class.getName()
            + " oneDatatype "
            + "where oneDatatype.targetSystem.targetSystemId = "
            + targetSystemId;

    //entityManager=ent;
    Query query = entityManager.createQuery(q);


    System.out.println("Query retrieveAll" + q);
    @SuppressWarnings("unchecked")
    List<Datatype> templates = query.getResultList();
    return templates;
}

}

上面的类基本上是我的DAO类,它将处理下面的查询,这是我的Web服务类

 @WebService(serviceName="backend")
    @Stateless
    public class backEndForm implements backEndFormRemote {
    //@PersistenceContext(name = "EJBtest")
    //EntityManager entityManager;

   private datatypesRemote data= new datatypes();

        public List<Datatype> retrieveAllDatatypes(int id){      
            //entityManager.clear();
            data=new datatypes();
            return  data.retrieveAllDatatypes(id,null);
        }
    }

现在问题是这样我的Web客户端调用我的Web服务方法,该方法进一步调用DAO方法,这些方法将从数据库获取数据并返回到Web服务,Web服务将数据返回给请求客户端 但是当我执行我的SQL查询时,实体管理器为空我不知道为什么我开发的非标准解决方案是将实体管理器从Web服务类传递到DAO类,如样本中所示已注释掉的代码。

所以我的问题是,还有其他标准方法吗?为什么实体管理器在第二个ejb3 bean中为空而不在第一个ejb3 bean中?

1 个答案:

答案 0 :(得分:0)

使用new运算符创建对象时不会发生注入。您需要让容器创建datatypes bean并将其注入backEndForm

@WebService(serviceName="backend")
@Stateless
public class backEndForm implements backEndFormRemote {

    @EJB
    private datatypesRemote data;

    public List<Datatype> retrieveAllDatatypes(int id){      
        return  data.retrieveAllDatatypes(id,null);
    }
}