这是我的DAO实现,我将加载整个表并在内存中缓存一段时间
@ApplicationScoped
public class DataAccessFacade {
@Inject
private EntityManager em;
@CacheOutput
public Map<String, String> loadAllTranslation() {
List<Translation> list = em.createQuery("select t from Translation t").getResultList();
Map<String, String> result = new HashMap<String, String>();
// do more processing here, omitted for clarity
return result;
}
public String getTranslation(String key) {
return loadAllTranslation().get(key);
}
}
这是我的球衣客户
@Inject
DataAccessFacade dataAccessFacade;
@Path("/5")
@GET
@Produces(MediaType.TEXT_PLAIN)
public String t5(@QueryParam("id") String key) {
// load the data from dataAccessFacade
String text = dataAccessFacade.getTranslation(key);
String text2 = dataAccessFacade.loadAllTranslation().get(key);
}
在客户端如果我调用dataAccessFacade.loadAllTranslation(),我将看到拦截器逻辑已被执行
如果我调用dataAccessFacade.getTranslation()在内部调用loadAllTranslation(),那么我没有看到拦截器被执行
这里有什么问题?
如何解决?
答案 0 :(得分:2)
这是CDI规范中的正确行为。只有“客户”类调用的方法才被视为“业务方法”,因此被截获。
答案 1 :(得分:1)
在DataAccessFacade中执行以下操作:
@Inject
private Provider<DataAccessFacade> self;
public String getTranslation(String key) {
return self.get().loadAllTranslation().get(key);
}
答案 2 :(得分:-1)
绑定到类的拦截器将拦截所有方法。看起来您已选择将拦截器(@CacheOutput?)绑定到特定方法而不是类级别。
我想如果除了loadAllTranslation之外你明确地将你的拦截器绑定到getTranslation方法,那么你会看到拦截器在这两种情况下工作。
我在说明书中没有找到任何解释当前行为的解释。我的猜测是它可以被认为是一种封装(信息隐藏)。在外部,没有理由期望调用getTranslation会导致调用loadAllTranslation。如果作为调用getTranslation(没有显式注释)的结果调用拦截器,则可以将其视为泄漏类的内部工作的细节。