java在注解中綁定方法參數的解決方案


我們有這樣子的需求,需要記錄用戶操作某個方法的信息並記錄到日志里面,例如,用戶在保存和更新任務的時候,我們需要記錄下用戶的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 "" ; } `` 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

然后我們在controller中定義一個方法,即用戶具體調用的保存或者更新的方法

@RequestMapping("/mvc24") @Logger(param1 = "#{task.project.projectName}",param2 = "#{task.taskName}",param3 = "#{name}",param4 = "常量") public void mvc24(Task task ,String name){ //... }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在這里我們就可以把參數中的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 ; } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

AnnotationResolver是我這邊寫的一個解析注解類語法的一個解析器,利用該解析器,可以把注解類中這樣子的語法直接解析#{方法變量名} 
該解析器只有唯一的一個方法

/** * 解析注解上的值 * @param joinPoint 切面類,直接在aop里面獲取,參考上面的例子 * @param str 需要解析的字符串 * @return */ public Object resolver(JoinPoint joinPoint, String str) 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

通過該地址下載

https://github.com/liuxg2013/AnnotationResolver.git


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM