我們有這樣子的需求,需要記錄用戶操作某個方法的信息并記錄到日志里面,例如,用戶在保存和更新任務的時候,我們需要記錄下用戶的ip,具體是保存還是更新,調用的是哪個方法,保存和更新的任務名稱以及操作是否成功。
這里最好的技術就是spring aop + annotation,首先我來定義個注解類
/**
* 參數命名好麻煩,我就隨便了,只是演示下用法
*@author liuxg
*@date 2016年4月13日 上午7:53:52
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Logger {
String param1() default "";
String param2() default "" ;
String param3() default "" ;
String param4() default "" ;
}
``
然后我們在controller中定義一個方法,即用戶具體調用的保存或者更新的方法
@RequestMapping("/mvc24")
@Logger(param1 = "#{task.project.projectName}",param2 = "#{task.taskName}",param3 = "#{name}",param4 = "常量")
public void mvc24(Task task ,String name){
//...
}
在這里我們就可以把參數中的task或者name的相關信息綁定到注解類中
然后我們再定義一個切面,我們就可以動態的獲取和處理注解類的一些信息了
/**
* 日志切面
*@author liuxg
*@date 2015年10月13日 下午5:55:44
*/
@Component
@Aspect
public class LoggerAspect {
@Around("@annotation(com.liuxg.logger.annotation.Logger)")
public Object around(JoinPoint joinPoint) {
MethodSignature methodSignature = (MethodSignature)joinPoint.getSignature();
Method method = methodSignature.getMethod();
Logger logger = (Logger) method.getAnnotation(Logger.class);
Object value1 = AnnotationResolver.newInstance().resolver(joinPoint, logger.param1());
Object value2 = AnnotationResolver.newInstance().resolver(joinPoint, logger.param1());
Object value3 = AnnotationResolver.newInstance().resolver(joinPoint, logger.param1());
Object value4 = AnnotationResolver.newInstance().resolver(joinPoint, logger.param1());
return null ;
}
}
AnnotationResolver是我這邊寫的一個解析注解類語法的一個解析器,利用該解析器,可以把注解類中這樣子的語法直接解析#{方法變量名}
該解析器只有唯一的一個方法
/**
* 解析注解上的值
*@param joinPoint 切面類,直接在aop里面獲取,參考上面的例子
*@param str 需要解析的字符串
*@return
*/
public Object resolver(JoinPoint joinPoint, String str)
通過該地址下載