我已经根据建议写了我的切入点和习惯,这将执行一个Dao方法。
切入点
@Pointcut("execution(* com.dao.*.get*(..))")
public void creditPointcut(){
}
围绕建议
@Around("creditPointcut()")
public void around(ProceedingJoinPoint point) throws Throwable{
LOGGER.info("Method name: "+point.getSignature().getName()+" started");
point.proceed();
LOGGER.info("Method name: "+point.getSignature().getName()+" ended");
}
目标 - 道方法
public Account getAccountDetails(int accntNo) {
Session session = sessionFactory.getCurrentSession();
Query query = session.createQuery("from Account where accountNo=:acctNo");
query.setInteger("acctNo", accntNo);
Account account = (Account)query.list().get(0);
return account;
}
但是,这个建议会在我的服务中返回null帐户。
服务层方法
@Override
@Transactional(isolation=Isolation.READ_COMMITTED )
public Account getAccountDetails(int accntNo) {
Account account = accountDao.getAccountDetails(accntNo);
return account;
}
在Dao执行周围的建议后,请帮助我为什么我的服务中有空帐户。
答案 0 :(得分:12)
那是因为你没有从建议中回复任何东西:
@Around("creditPointcut()")
public Object around(ProceedingJoinPoint point) throws Throwable{
LOGGER.info("Method name: "+point.getSignature().getName()+" started");
Object ret = point.proceed();
LOGGER.info("Method name: "+point.getSignature().getName()+" ended");
return ret;
}