aspectjweaver AspectJ

aspectjweaver AspectJ基于aop的依赖jar包,可以实现切面过滤拦截。依赖包:<!–https://mvnrepository.com/artifact/org.aspectj/aspectjweaver–><dependency><groupId>org.aspectj</groupId><artifactId>asp…

大家好,又见面了,我是你们的朋友全栈君。

基于aop的依赖jar包,可以实现切面过滤拦截。

依赖包:

<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.8.0.RELEASE</version>
</dependency>

使用:

1.@Aspect和@Configuration添加到定义的Aspect类上,指明切面类。

2.定义切点:@Pointcut(“execution(* com.controller.Test2Controller.*(..))”)

将@Pointcut定义到切点方法上

3.切面过滤注解:

@Before(“pointcut()”)

@Around(“pointcut()”)

@AfterReturning(value = “pointcut()”,returning = “returnValue”)

@After(“pointcut()”)

@AfterThrowing

这几个注解的过滤顺序为:

@Around-joinPoint.proceed(args)前

@Before

@Around-joinPoint.proceed(args)后

@After

@AfterReturning/@AfterThrowing

4.举个栗子:

import com.alibaba.fastjson.JSON;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Configuration;

import java.util.Arrays;

@Aspect
@Configuration
public class TestAspect {

    Logger logger = LoggerFactory.getLogger(getClass());

    // 定义切点Pointcut
    @Pointcut("execution(* .test.Test2Controller.*(..))")
    public void pointcut() {
        logger.info("pointcut---------------execute");
    }


    @Before("pointcut()")
    public void before(){
        logger.info("@Before------------execute");
    }

    @Around("pointcut()")
    public Object around(ProceedingJoinPoint joinPoint) throws Throwable{

        Signature signature = joinPoint.getSignature();
        logger.info("@Around-joinPoint.proceed(args)前");
        logger.info("@Around-执行目标方法前参数:"+Arrays.toString(joinPoint.getArgs()));
        Object[] args = joinPoint.getArgs();
        if(args != null &&args.length>0){
            args[0]="update";
        }
        Object proceed = joinPoint.proceed(args);
        logger.info("@Around-joinPoint.proceed(args)后");
        logger.info("@Around-被织入的目标对象:" + joinPoint.getTarget());
        logger.info("@Around-返回值:"+JSON.toJSONString(proceed));
        return JSON.toJSONString(proceed);
    }

    @AfterReturning(value = "pointcut()",returning = "returnValue")
    public void afterReturning(JoinPoint point, Object returnValue) {
        logger.info("@AfterReturning-方法:"+point.getSignature().getDeclaringTypeName()+point.getSignature().getName());
        logger.info("@AfterReturning-参数:"+Arrays.toString(point.getArgs()));
        logger.info("@AfterReturning-返回值:" + returnValue);
        logger.info("@AfterReturning-被织入的目标对象:" + point.getTarget());
    }

    @After("pointcut()")
    public void after(JoinPoint point){
        logger.info("@After-方法:"+point.getSignature().getDeclaringTypeName()+point.getSignature().getName());
        logger.info("@After-参数:"+Arrays.toString(point.getArgs()));
        logger.info("@After-被织入的目标对象:" + point.getTarget());
    }
    @AfterThrowing("pointcut()")
    public void afterThrowing(JoinPoint point){
        logger.info("@AfterThrowing-----",point.getTarget());
    }

}

控制台:

2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.around(TestAspect.java:36)
-@Around-joinPoint.proceed(args)前
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.around(TestAspect.java:37)
-@Around-执行目标方法前参数:[null]
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.before(TestAspect.java:29)
-@Before------------execute
执行test-----update
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.around(TestAspect.java:43)
-@Around-joinPoint.proceed(args)后
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.around(TestAspect.java:44)
-@Around-被织入的目标对象:net.buybal.order.controller.test.Test2Controller@155814e5
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.around(TestAspect.java:45)
-@Around-返回值:"update"
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.after(TestAspect.java:59)
-@After-方法:net.buybal.order.controller.test.Test2Controllertest
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.after(TestAspect.java:60)
-@After-参数:[update]
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.after(TestAspect.java:61)
-@After-被织入的目标对象:net.buybal.order.controller.test.Test2Controller@155814e5
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.afterReturning(TestAspect.java:51)
-@AfterReturning-方法:net.buybal.order.controller.test.Test2Controllertest
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.afterReturning(TestAspect.java:52)
-@AfterReturning-参数:[update]
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.afterReturning(TestAspect.java:53)
-@AfterReturning-返回值:"update"
2019-11-26 17:22:56 [http-bio-9998-exec-1] INFO -Caller+0    at *.TestAspect.afterReturning(TestAspect.java:54)
-@AfterReturning-被织入的目标对象:net.buybal.order.controller.test.Test2Controller@155814e5
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.around(TestAspect.java:36)
-@Around-joinPoint.proceed(args)前
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.around(TestAspect.java:37)
-@Around-执行目标方法前参数:[null]
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.before(TestAspect.java:29)
-@Before------------execute
执行test-----update
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.after(TestAspect.java:59)
-@After-方法:net.buybal.order.controller.test.Test2Controllertest
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.after(TestAspect.java:60)
-@After-参数:[update]
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.after(TestAspect.java:61)
-@After-被织入的目标对象:net.buybal.order.controller.test.Test2Controller@2965bb5f
2019-11-26 17:19:27 [http-bio-9998-exec-1] INFO -Caller+0    at *.aspect.TestAspect.afterThrowing(TestAspect.java:65)
-@AfterThrowing-----

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157905.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • event.srcElement 用法笔记

    event.srcElement 用法笔记event.srcElement可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称。event.srcElement.TagName//事件对象的h

    2022年7月2日
    29
  • linux系统下codeblocks控制台打印中文乱码[通俗易懂]

    linux系统下codeblocks控制台打印中文乱码[通俗易懂]linux系统下codeblocks控制台打印中文乱码在linux下安装codeblocks后,打印中文出现如下问题:#include<stdio.h>#include<stdlib.h>intmain(){printf(“你好,世界!\n”);return0;}解决办法1、将Settings-&…

    2022年7月14日
    12
  • navicat激活码2021-激活码分享

    (navicat激活码2021)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月22日
    444
  • BP神经网络原理及matlab实例

    BP神经网络原理及matlab实例转载:http://blog.csdn.net/u013007900/article/details/50118945上一次我们讲了M-P模型,它实际上就是对单个神经元的一种建模,还不足以模拟人脑神经系统的功能。由这些人工神经元构建出来的网络,才能够具有学习、联想、记忆和模式识别的能力。BP网络就是一种简单的人工神经网络。 本文具体来介绍一下一种非常常见的神经网络模型——反

    2022年7月20日
    13
  • 美化包软件_手机主题美化软件

    美化包软件_手机主题美化软件前言在我们进行自动化测试的时候,用例往往是成百上千,执行的时间是几十分钟或者是小时级别。有时,我们在调试那么多用例的时候,不知道执行到什么程度了,而pytest-sugar插件能很好解决我们的痛点。

    2022年7月31日
    5
  • 手把手教你用Hexo+Github 搭建属于自己的博客「建议收藏」

    手把手教你用Hexo+Github 搭建属于自己的博客「建议收藏」欢迎关注我的微信公众号,扫一扫下方二维码或搜索微信号stormjun,即可关注。目前专注于Android开发,主要分享Android开发相关知识和一些相关的优秀文章,包括个人总结,职场经验等。闲聊在大三的时候,一直就想搭建属于自己的一个博客,但由于各种原因,最终都不了了之,恰好最近比较有空,于是就自己参照网上的教程,搭建了属于自己的博客。至于为什么要搭建自己的博客了?

    2022年7月27日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号