0

对不起我的英语,我有一个带有 cdi 1.0、deltaspike 0.5 和 primefaces 4.0 的战争项目,当我尝试将 @Respository 与 @EntityManagerConfig 一起使用时,因为我有两个具有不同 @Qualifiers 的 entityManager 产品,我正在使用glassfish 4 用于应用程序服务器,这是 Repository、Produces 和 EntityManagerResolver 的解码代码:

存储库:

@Repository(forEntity = User.class)
@EntityManagerConfig(entityManagerResolver = HbsWebEntityManagerResolver.class, flushMode = FlushModeType.AUTO)
public abstract class UserRepository extends
    AbstractEntityRepository<User, Integer> {

   @Query(named = User.BY_LOGIN)
   public abstract User findByLoginEqual(@QueryParam("login") String login);

}

实体管理器解析器:

public class HbsWebEntityManagerResolver implements EntityManagerResolver{

    @Inject
    @HbsWeb
    private EntityManager hbsWebEntityManager;

    @Override
    public EntityManager resolveEntityManager() {       
        return hbsWebEntityManager;
}

}

产生:

@ApplicationScoped
public class EntityManagerProducer {

    @PersistenceUnit(unitName="HBS")
        private EntityManagerFactory hbsEntityManager;

    @PersistenceUnit(unitName="HBSWEB")
    private EntityManagerFactory hbsWebEntityManager;

    @Produces
    @Hbs    
    protected EntityManager createHbsEntityManager() {
        return hbsEntityManager.createEntityManager();
    }

    protected void closeHbsEntityManager(
            @Disposes @Hbs EntityManager entityManager) {
        if (entityManager.isOpen()) {
            entityManager.close();
        }
    }

    @Produces
    @HbsWeb 
    protected EntityManager createHbsWebEntityManager() {
        return hbsWebEntityManager.createEntityManager();
    }

    protected void closeHbsWebEntityManager(
            @Disposes @HbsWeb EntityManager entityManager) {
        if (entityManager.isOpen()) {
            entityManager.close();
        }
    }

}

当我尝试将存储库与 @inject 一起使用时,出现以下错误:

org.apache.deltaspike.data.impl.handler.QueryInvocationException: Exception calling Repository: [Repository=class    co.com.compuhelmac.hbs.repository.UserRepository_$$_javassist_0,method=findByLoginEqual],exception=class org.jboss.weld.exceptions.AmbiguousResolutionException,message=WELD-001318 Cannot resolve an ambiguous dependency between [Producer Method [EntityManager] with qualifiers [@Hbs @Any] declared as [[BackedAnnotatedMethod] @Produces @Hbs protected co.com.compuhelmac.hbs.database.EntityManagerProducer.createHbsEntityManager()], Producer Method [EntityManager] with qualifiers [@HbsWeb @Any] declared as [[BackedAnnotatedMethod] @Produces @HbsWeb protected co.com.compuhelmac.hbs.database.EntityManagerProducer.createHbsWebEntityManager()]]
    at org.apache.deltaspike.data.impl.handler.QueryHandler.invoke(QueryHandler.java:86)
    at org.apache.deltaspike.partialbean.impl.PartialBeanAbstractMethodHandler.invoke(PartialBeanAbstractMethodHandler.java:44)
    at org.apache.deltaspike.partialbean.impl.MethodHandlerProxy.invoke(MethodHandlerProxy.java:35)
    at com.sun.proxy.$Proxy549.invoke(Unknown Source)
    at co.com.compuhelmac.hbs.repository.UserRepository_$$_javassist_0.findByLoginEqual(UserRepository_$$_javassist_0.java)
    at co.com.compuhelmac.hbs.security.HbsLoginEJB.login(HbsLoginEJB.java:46)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1081)
    at org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1153)
    at com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:4695)
    at com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:630)
    at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:822)
    at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:582)
    at org.jboss.weld.ejb.AbstractEJBRequestScopeActivationInterceptor.aroundInvoke(AbstractEJBRequestScopeActivationInterceptor.java:46)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

Caused by: org.jboss.weld.exceptions.AmbiguousResolutionException: WELD-001318 Cannot resolve an ambiguous dependency between [Producer Method [EntityManager] with qualifiers [@Hbs @Any] declared as [[BackedAnnotatedMethod] @Produces @Hbs protected co.com.compuhelmac.hbs.database.EntityManagerProducer.createHbsEntityManager()], Producer Method [EntityManager] with qualifiers [@HbsWeb @Any] declared as [[BackedAnnotatedMethod] @Produces @HbsWeb protected co.com.compuhelmac.hbs.database.EntityManagerProducer.createHbsWebEntityManager()]]
    at org.jboss.weld.manager.BeanManagerImpl.resolve(BeanManagerImpl.java:1154)
    at org.jboss.weld.manager.BeanManagerImpl.getBean(BeanManagerImpl.java:798)
    at org.jboss.weld.bean.builtin.InstanceImpl.get(InstanceImpl.java:79)
    at org.apache.deltaspike.data.impl.handler.EntityManagerLookup.lookupFor(EntityManagerLookup.java:51)
    at org.apache.deltaspike.data.impl.handler.QueryHandler.createContext(QueryHandler.java:97)
    at org.apache.deltaspike.data.impl.handler.QueryHandler.invoke(QueryHandler.java:74)

有谁知道为什么会发生这个错误?

4

2 回答 2

0

您的 EM 解析器被调用,但问题是尝试注入

@Inject
@HbsWeb
private EntityManager hbsWebEntityManager;

由于存在以下问题:createHbsWebEntityManager() 和 createHbsEntityManager()

@HbsWeb 和 @Hbs 是如何定义的?他们有关系吗?

于 2014-03-31T11:25:03.543 回答
0

通过你的堆栈跟踪

org.apache.deltaspike.data.impl.handler.EntityManagerLookup.lookupFor(EntityManagerLookup.java:51)

并查看 DeltaSpike 0.5 的来源,我会说这是 0.5 版本中的一个错误,因为从EntityManager获得的EntityManagerResolver从未使用过。

再试一次 DeltaSpike 0.6-SNAPSHOT - Data 模块有很多改进,现在这段特殊的代码看起来更正确。

于 2014-02-20T19:04:06.387 回答