Spring AOP自定义Annotation搭配log4j做日志
2016-07-28 18:55
459 查看
概况:
项目框架:Spring4,Hibernate4,SpringMVC项目结构:使用了最常用的model,dao,service,controller
我的项目是在service层控件事务,运行日志也加在service层。
aop作用的是xml配置
涉及到的点:
1、自定义Annotation2、使用SpringAOP
3、AOP通知参数
步骤:
1、自定义Annotation
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface LogInfo { public String value() default""; }
介绍一下,只有一个默认值,下面会介绍怎么使用。
2、给service方法添加自定义Annotation
@LogInfo("获取验证码(老婆设备号),") @Override public HusRegister getCheckCode(String wifeDevice) { HusRegister husRegister = registerDao.findHusRegisterByWifeDevice(wifeDevice); return initRegister(husRegister, wifeDevice); }重要的点:
1、service层也是面向接口编程,这个Annotation要加在实现类的方法中,不能加在接口方法中,否则AOP获取不到
2、如图,自定义的Annotation里面增加的是日志要输出的,就是这个方法的作用,还有方法的参数作用,最后在日志中可以看到
3、注意,这个service已经被Spring管理,已经加入事务。同时也加入了AOP。
3、SpringAOP的配置
<aop:aspect id="registerLog" ref="registerLog"> <aop:pointcut expression="execution(* hus.register.service.*.*(..)) and @annotation(logInfo)" id="servicePointcut" /> <aop:after method="log" pointcut-ref="servicePointcut" arg-names="logInfo" /> </aop:aspect>
如图,是AOP其中一个的配置,expression定义了在哪些方法中加入,重点是后面的,
and @annotation(logInfo)
<aop:after method="log" pointcut-ref="servicePointcut" arg-names="logInfo" />logInfo是我自定义的参数。下面看一下log方法就知道怎么回事了。
@Component("registerLog") public class RegisterLog { public static final Logger LOGGER = Logger.getLogger(RegisterLog.class); public void log(JoinPoint joinPoint, LogInfo logInfo) { LOGGER.info(logInfo.value() + StaticTool.toJSon(joinPoint.getArgs())); } }@Component是声明这个组件,使它被Spring控制,声明的id是registerLog,所以xml中的 ref="registerLog"使用的是它
上面的xml中aop:after,看一下这个配置,再看一下log方法,第二个参数logInfo,就是这么来了,
第一个参数,是默认就会加入的,不用在arg-names里面声明
4、效果
log4j的配置就不贴出来了,给大家看一下日志的效果:2016-07-28 14:21:59 INFO RegisterLog:13 : 获取验证码(设备号),["863121023684624"]
获取了Annotation,并把它当作日志输出,这样我们就可以非常容易地控制方法的执行时候的日志记录,并且可以记录到参数,以后记录的时候会非常方便。
相关文章推荐
- Struts2之No result defined for action错误
- JAVA中的类与类加载的顺序(好多初学者的困惑之处)
- jdk动态代理和cglib的区别
- Spring集成Quartz定时任务框架介绍和Cron表达式详解
- Java编程规范-----来源于java编程思想
- linphone-LinphoneInfoMessage.java文件分析
- Spring
- java对数据库进行增删改查的封装(封装以后只要一句话就搞定对数据库的增删改查)
- eclipse 启动 org.eclipse.jst.servlet.ui was unable to instantiate class
- 线程“死亡”后的反思
- <JAVA>学习笔记10>——多个客户端连接服务器
- SpringMVC+easyui
- 二维码生成和解析
- JAVA中参数传递的迷惑点
- spring intergration 例子
- Java中对象的引用
- Spring常用注解
- Struts2向action传对象数组
- Java_集合_List
- Spring Data JPA书写原生态sql拼接