Spring AOP自定义Annotation搭配log4j做日志

本文介绍了如何在Spring MVC、Hibernate、Spring框架下,通过自定义Annotation结合Spring AOP来实现日志功能。在项目结构中,日志主要在service层进行控制。首先,自定义了一个Annotation,接着在service方法上应用该Annotation,然后配置Spring AOP进行拦截处理,最终实现了运行日志的记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

概况:

项目框架:Spring4,Hibernate4,SpringMVC

项目结构:使用了最常用的model,dao,service,controller

我的项目是在service层控件事务,运行日志也加在service层。

aop作用的是xml配置

涉及到的点:

1、自定义Annotation
2、使用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,并把它当作日志输出,这样我们就可以非常容易地控制方法的执行时候的日志记录,并且可以记录到参数,以后记录的时候会非常方便。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值