读书人

Spring aop 关于around环绕通知几点疑

发布时间: 2013-10-21 17:00:48 作者: rapoo

Spring aop 关于around环绕通知几点疑惑


个人aop拦截了所有service的接口 : I*Service


public Object doLog(ProceedingJoinPoint pjp) throws Exception {


String methodName = pjp.getSignature().getName();//获取方法名

Object target = pjp.getTarget();//目标类我是aop拦截了I*Service 此处获取的target是实现类还是接口类?

String className = ReflectionUtils.getClassName(target.getClass());//通过反射获取该类名

Object[] args = pjp.getArgs();//获取所有参数

System.out.println("className = " + className);

if (StringUtils.hasLength(methodName)) {
if (methodName.equals("getUser")) { //此处 我只能去匹配字符来知道是走哪个方法吗? 如果我一个接口内方法重载了可咋办呢、 比如getUser(通过id获取) 和gerUser(通过帐号密码获取)
iLogService.logMainMgrUserChange(args);//此处方法会把参数分解去保存到数据库
}

}

return pjp.proceed();


}




如果我想在重要的接口才log、 比如一些重要的操作、

我如何才能在不使用字符串去匹配方法名 去记录日志

感觉这样处理有些不是那么好、

有没有类似反射这样的或者其他 的方法去比对是否是我想要的接口方法?


可能我描述的不是那么明白、请告之、先谢谢各位、
[解决办法]
这个还真没有 好像 , 你自己写一个吧! 就不判断methodName直接判断Method 这个对象

读书人网 >J2EE开发

热点推荐