码迷,mamicode.com
首页 > 编程语言 > 详细

spring 中aop 切面实践

时间:2020-10-22 22:49:05      阅读:30      评论:0      收藏:0      [点我收藏+]

标签:runtime   remote   target   void   enc   spec   mos   policy   inter   

切面相关注解:

@Aspect : 声明该类为一个注解类

@Pointcut : 定义一个切点

@Before : 在切点之前执行

@After : 在切点之后执行 不管目标方法是否执行成功

@AfterReturning : 切点返回内容后执行代码,可以对切点的返回值进行封装

@AfterThrowing : 切点抛出异常后执行

@Around : 环绕,在切点前后执行代

 

1.自定义注解:

@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface timingAnnotation {
}

2.切面类

@Aspect
@Component
@Slf4j
public class AspectDemo {

    @Pointcut("@annotation(com.wl.demo.demos.aop.timingAnnotation)")
    public void pointCut() {
    }

    @Before("pointCut()")
    public void doBefore(JoinPoint joinPoint) {
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        log.info("IP: {}", request.getRemoteAddr());
        log.info("URL: {}", request.getRequestURL().toString());
        log.info("HTTP Method: {}", request.getMethod());
        log.info("Class Method: {}.{}", joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName());
    }

    @Around("pointCut()")
    public Object doAround(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
        long startTime = System.currentTimeMillis();
        MethodSignature methodSignature = (MethodSignature) proceedingJoinPoint.getSignature();
        Object proceed = proceedingJoinPoint.proceed();
        long endTime = System.currentTimeMillis();
        log.info("[方法耗时]" + methodSignature.getDeclaringTypeName() + "." + methodSignature.getMethod().getName() + " 耗时: " + (endTime - startTime) + "毫秒");
        return proceed;
    }


    @After("pointCut()")
    public void doAfter(JoinPoint joinPoint) {
        log.info("目标方法执行完之后执行");
    }

    @AfterThrowing(pointcut = "pointCut()", throwing = "e")
    public void doAfterThrow(JoinPoint joinPoint, RuntimeException e) {
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        log.info("HTTP Method: {}", request.getMethod());
        log.info("Class Method: {}.{}", joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName());
    }

}

注:引入aspect 需要引入jar:

<!--引入aop aspectj-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
    <scope>test</scope>
</dependency>
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
</dependency>

  

 

spring 中aop 切面实践

标签:runtime   remote   target   void   enc   spec   mos   policy   inter   

原文地址:https://www.cnblogs.com/wlong-blog/p/13857806.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!