Spring(12):使用注解(@AfterThrowing/@After/@Around)实现AOP异常增强与实例

本文详细介绍如何使用AOP(面向切面编程)在Java应用中实现日志记录功能,包括异常抛出、最终增强及环绕增强等不同类型的增强方法,并提供具体的代码实现。

2017/12/31

【1】异常抛出增强:

在包(com\smbms\AopLog)新建一个ErrorLogger.java:

 

package com.smbms.AopLog;

import org.apache.log4j.Logger;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;

@Aspect
public class ErrorLogger {
	private static final Logger log = Logger.getLogger(UserserviceLogger.class);
	
	@AfterThrowing(pointcut="execution(* com.smbms.pojo..*.*(..))",throwing="e")
	public void afterthrowing(JoinPoint jp,RuntimeException e){
		log.error(jp.getSignature().getName()+" ++++++*****++++ method exception happens!!!  ++++++*****++++: "+ e);
	}
}

 

 

解释:

 

1、@AfterThrowing 注解;

 

【2】最终增强:

 

在包(com\smbms\AopLog)新建一个AfterLogger.java:

 

package com.smbms.AopLog;

import org.apache.log4j.Logger;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;

@Aspect
//最终增强
public class AfterLogger {
	private static final Logger log = Logger.getLogger(UserserviceLogger.class);
	
	@After("execution(* com.smbms.pojo..*.*(..))")
	public void after(JoinPoint jp){
		log.info(jp.getSignature().getName()+"+++ method excute end!++");
	}

}

 

 

解释:

 

1、@After注解;

 

 

 

【3】环绕增强:

在包(com\smbms\AopLog)新建一个AroundLogger.java:

 

package com.smbms.AopLog;

import java.util.Arrays;

import org.apache.log4j.Logger;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;

@Aspect
public class AroundLogger {
	private static final Logger log = Logger.getLogger(UserserviceLogger.class);
	
	@Around("execution(* com.smbms.pojo..*.*(..))")
	public Object aroundLogger(ProceedingJoinPoint jp) throws Throwable {
		log.info("***UserserviceLogger*********before:调用了"+jp.getTarget()+" 的"+jp.getSignature().getName()
				+" 方法。方法入参:"+Arrays.toString(jp.getArgs()));
		try{
			Object result = jp.proceed();
			log.info("调用了 "+jp.getTarget()+" 的 "+jp.getSignature().getName()
					+" 方法。");
			return result;
		}catch(Throwable e){
			log.error(jp.getSignature().getName()+" Exception...方法发生异常: "+e);
			throw e;
		}finally{
			log.info(jp.getSignature().getName()+" ENDING.....方法执行结束");
		}
		
	}
}

 

 

解释:

1、@Around 注解

2、声明ProceedingJoinPoint 类型参数可以获取连接点的信息;

 

测试方法还在研究,因为异常发生时,控制台就不会输出,所以稍后再完善该博文。


欢迎扫二维码关注公众号,获取技术干货

 

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后台技术汇

对你的帮助,是对我的最好鼓励。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值