java在注解中绑定方法参数的解决方案
2016-04-14 16:15
429 查看
我们有这样子的需求,需要记录用户操作某个方法的信息并记录到日志里面,例如,用户在保存和更新任务的时候,我们需要记录下用户的ip,具体是保存还是更新,调用的是哪个方法,保存和更新的任务名称以及操作是否成功。
这里最好的技术就是spring aop + annotation,首先我来定义个注解类
然后我们在controller中定义一个方法,即用户具体调用的保存或者更新的方法
在这里我们就可以把参数中的task或者name的相关信息绑定到注解类中
然后我们再定义一个切面,我们就可以动态的获取和处理注解类的一些信息了
AnnotationResolver是我这边写的一个解析注解类语法的一个解析器,利用该解析器,可以把注解类中这样子的语法直接解析#{方法变量名}
该解析器只有唯一的一个方法
通过该地址下载
https://github.com/liuxg2013/AnnotationResolver.git
这里最好的技术就是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)
通过该地址下载
https://github.com/liuxg2013/AnnotationResolver.git
相关文章推荐
- java中汉字自动转换成拼音
- 20145109 实验二 Java面向对象程序设计
- java-乱码总结
- Java中Array.sort()的几种用法
- JAVA多线程与并发学习总结
- Java设置Swing窗体居中显示
- 小故障
- kafka java 生产消费程序demo示例
- spring mvc+Mybatis整合shiro 第三章 SessionManager
- Java冒泡排序法
- java中Date与String的相互转化
- 为什么java中用枚举实现单例模式会更好
- [疯狂Java]JDBC:ResultSetMetaData(结果集元数据分析)
- 【转】Spring bean处理——回调函数
- java.lang.NumberFormatException: For input string: "on"
- 默认建立的myeclipse web工程无法运行
- Java数字转字符串前面自动补0的实现
- 分布式事务操作之Spring+JTA+mybatis
- struts2开发4--自定义拦截器把不文明用语改变成***
- java垃圾回收机制