我现在有一个要求,就是当使用mybatis(特别是那些批处理执行sql)时,首先检查参数,如果参数为null或为空,则只返回,不要继续,如果返回类型是列表中,例如
List<User> getByIds(List<Long> idList)
返回空ArrayList,如果返回类型为void:
void batchInsert(List<User>)
返回null。 目的是避免这种情况,例如。
select * from user where id in ()
insert into user(name,email) values ()
但是从joinPoint我无法获得返回类型,只能获得args。
Object[] args = joinPoint.getArgs();
if(args!=null&&args.length=1){
if(args[0] instanceof List){
if(((List) obj).isEmpty()){
if(returnType.equals("java.util.List"))
return new ArrayList();
else if(returnType.equals("void"))
return null;
}
}
return joinPoint.proceed();
那么如何在aop中获得返回类型:around?
答案 0 :(得分:14)
要从ProceedingJoinPoint
获取方法返回类型/类,您可以执行此操作:
Signature signature = proceedingJoinPoint.getSignature();
Class returnType = ((MethodSignature) signature).getReturnType();