Spring AOP (二)

在Spring AOP初尝试里面,每个切面方法前面的切面都是一样的,此处可以将它们提出处理,用一个统一的空实现的方法来表示。

将上一篇的例子修改之后,如下。


package com;


import java.util.Arrays;
import java.util.List;


import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;


// Order 在多个切面的情况下,用来指定切面的优先级,数值越小,优先级越高
@Order(1)
@Aspect
@Component
public class ArithLoggingAspect {

// 此处方法一定要是空实现

// 类在同一个包下面的话,可以不用全类名
@Pointcut("execution(* Calculator.*(..))")
public void declarePointcut() {}


@Before("declarePointcut()")
public void beforeMethod(JoinPoint joinPoint) {
String methodName = joinPoint.getSignature().getName();
List<Object> args = Arrays.asList(joinPoint.getArgs());

System.out.println("The method " + methodName + " begins with " + args);
}

@After("declarePointcut()")
public void afterMethod(JoinPoint joinPoint) {
String methodName = joinPoint.getSignature().getName();
System.out.println("The method " + methodName + " ends");
}

// 此处returning="rtv"中的rtv与方法的参数Object rtv要名称一致
@AfterReturning(value="declarePointcut()",returning="rtv")
public void afterReturn(JoinPoint joinPoint, Object rtv) {
String methodName = joinPoint.getSignature().getName();
System.out.println("The method " + methodName + " return " + rtv);
}

// 此处throwing="e"指定了Exception e参数变量名
@AfterThrowing(value="declarePointcut()",throwing="e")
public void afterException(JoinPoint joinPoint,Exception e) {
String methodName = joinPoint.getSignature().getName();
System.out.println("The method " + methodName + " exception ");
e.printStackTrace();
}

// @Around必须有返回值,而且返回值必须是proceed的返回值
@Around("declarePointcut()")
public Object around(ProceedingJoinPoint pjp) throws Throwable {
List<Object> args = Arrays.asList(pjp.getArgs());
System.out.println("around " + args);
return pjp.proceed();
}
}


PS:如果是要引用其他类里面的切面声明,就在declarePointcut()前面加上类的全类名


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值