springboot 使用自定义的aspect的示例代码

作者:张占岭 时间:2023-08-06 08:55:14 

对某个类型中的方法进行拦截,然后加入固定的业务逻辑,这是AOP面向切面编程可以做的事,在springboot里实现aop的方法也有很多, spring-boot-starter-aop 或者 aspectjweaver 都是可以实现的,不过我们在实现之前,先来看一下aop里的几个概念。

概念

  • 切面(Aspect):是指横切多个对象的关注点的一个模块化,事务管理就是J2EE应用中横切关注点的很好示例。在Spring AOP中,切面通过常规类(基本模式方法)或者通过使用了注解@Aspect的常规类来实现。

  • 连接点(Joint point):是指在程序执行期间的一个点,比如某个方法的执行或者是某个异常的处理。在Spring AOP中,一个连接点往往代表的是一个方法执行。

  • 通知(Advice):是指切面在某个特殊连接点上执行的动作。通知有不同类型,包括"around","before"和"after"通知。许多AOP框架包括Spring,将通知建模成一个 * ,并且围绕连接点维持一个 * 链。

  • 切入点(Pointcut):是指匹配连接点的一个断言。通知是和一个切入点表达式关联的,并且在任何被切入点匹配的连接点上运行(举例,使用特定的名字执行某个方法)。AOP的核心就是切入点表达式匹配连接点的思想。Spring默认使用AspectJ切入点表达式语

  • 引入(Introduction):代表了对一个类型额外的方法或者属性的声明。Spring AOP允许引入新接口到任何被通知对象(以及一个对应实现)。比如,可以使用一个引入去使一个bean实现IsModified接口,从而简化缓存机制。(在AspectJ社区中,一个引入也称为一个inter-type declaration类型间声明)

  • 目标对象(Target object):是指被一个或多个切面通知的那个对象。也指被通知对象("advised object"),由于Spring AOP是通过运行时代理事项的,这个目标对象往往是一个代理对象。

  • AOP 代理(AOP proxy):是指通过AOP框架创建的对象,用来实现切面合约的(执行通知方法等等)。在Spring框架中,一个AOP代理是一个JDK * 或者是一个CGLIB代理。

  • 织入(Weaving):将切面和其他应用类型或者对象连接起来,创骗一个被通知对象。这些可以在编译时(如使用AspectJ编译器)、加载时或者运行时完成。Spring AOP,比如其他纯Java AOP框架一般是在运行时完成织入。

实现

1 引用依赖包


<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

2 添加切面和拦截的行为


@Aspect
@Component
@Slf4j
public class TestAspect {

/**
 * 对TestService类下面的所有方法拦截.
 */
@Pointcut("execution(* com.lind.start.test.aop.TestService.*(..))")
public void pointcut() {
}

//前置通知
@Before("pointcut()")
public void beforeMethod(JoinPoint joinPoint) {
 if (joinPoint.getArgs().length == 1 && joinPoint.getArgs()[0] instanceof User) {
  User user = (User) joinPoint.getArgs()[0];
  user.setUsername("aop赋值");
  log.info("调用了前置通知" + user.toString());
 }

}

//@After: 后置通知
@After("pointcut()")
public void afterMethod(JoinPoint joinPoint) {
 log.info("调用了后置通知");
}

//@AfterRunning: 返回通知 result为返回内容
@AfterReturning(value = "pointcut()", returning = "result")
public void afterReturningMethod(JoinPoint joinPoint, Object result) {
 log.info("调用了返回通知");
}

//@Around:环绕通知
@Around("pointcut()")
public Object Around(ProceedingJoinPoint pjp) throws Throwable {
 log.info("around执行方法之前");
 Object object = pjp.proceed();
 log.info("around执行方法之后--返回值:" + object);
 return object;
}

}

3 调用及结果


@SpringBootTest
@RunWith(SpringRunner.class)
public class AopTest {
@Autowired
TestService testService;

@Test
public void test() {
 testService.print(new User());
}
}

springboot 使用自定义的aspect的示例代码

来源:http://www.cnblogs.com/lori/p/13437986.html

标签:springboot,aspect
0
投稿

猜你喜欢

  • 使用JVM常用GC日志打印参数

    2021-09-06 17:36:41
  • Android 虚拟按键适配动态调整布局的方法

    2022-03-03 07:20:24
  • 详解Android的两种事件处理机制

    2023-10-05 23:37:20
  • mybatis之如何获取表中某一列的最大值

    2022-03-26 08:38:53
  • Android 通知栏的使用方法

    2022-11-12 20:00:29
  • java中拼接字符串的5种方法效率对比

    2022-01-08 05:46:18
  • C#检测上传文件真正类型的方法

    2021-10-28 11:32:59
  • springboot使用之多个filter的执行顺序以及配置方式

    2023-11-09 09:30:59
  • HttpClient 在Java项目中的使用详解

    2021-12-06 02:36:57
  • Android 架构之数据库框架搭建

    2021-09-28 23:26:06
  • spring-boot-maven-plugin:打包时排除provided依赖问题

    2023-07-18 02:12:11
  • Android实现视频播放--腾讯浏览服务(TBS)功能

    2021-09-06 20:13:10
  • Java 实战项目锤炼之网上图书馆管理系统的实现流程

    2021-10-09 02:05:34
  • Windows下RabbitMQ安装及配置详解

    2022-04-29 08:11:18
  • JAVA基础之一些不为人知的那些秘密

    2023-11-29 07:49:29
  • Java执行JS脚本工具

    2022-04-07 08:00:16
  • 基于eclipse.ini内存设置的问题详解

    2021-08-25 02:56:55
  • 提示出现unresolved external symbol _main的解决方法

    2023-02-13 03:41:48
  • spring boot补习系列之几种scope详解

    2022-06-10 13:39:13
  • java并发之ArrayBlockingQueue详细介绍

    2023-04-23 07:30:01
  • asp之家 软件编程 m.aspxhome.com