[原创]【注解驱动开发3】- AOP

简介: [原创]【注解驱动开发3】- AOP

一. 使用



  • 目标方法

interface DivService {
    default int div(int a, int b) {
        return a / b;
    }
}
/**
 * 业务逻辑,目标方法
 */
@Slf4j
@Service
class DivServiceImpl implements DivService {
    @Override
    public int div(int a, int b) {
        log.info("div目标方法被执行...");
        return a / b;
    }
}
  • 定义切面

/**
 * LogAop
 */
@Component
@Slf4j
@Aspect
class LogAspect {
    @Pointcut("execution(public int com.futao.springmvcdemo.test.aspect.DivService.*(..))")
    public void pointCut() {
    }
    @Before("pointCut()")
    public void before(JoinPoint point) {
        log.info("【{}】方法执行前@Before,参数列表:【{}】", point.getSignature().getName(), point.getArgs());
    }
    /**
     * 无论目标方法是否成功,都会执行该方法
     *
     * @param point
     */
    @After(value = "pointCut()")
    public void after(JoinPoint point) {
        log.info("【{}】方法执行后@After", point.getSignature().getName());
    }
    @AfterReturning(value = "pointCut()", returning = "result")
    public void afterReturning(JoinPoint point, Object result) {
        log.info("【{}】方法执行后正常返回@AfterReturning,返回值:【{}】", point.getSignature().getName(), result);
    }
    @AfterThrowing(value = "pointCut()", throwing = "e")
    public void afterThrowing(JoinPoint point, Exception e) {
        log.error("【{}】方法执行后发生异常,异常信息为【{}】", point.getSignature().getName(), e.getMessage());
    }
}
  • 定义配置类,开启AspectJ动态代理

@ComponentScan("com.futao.springmvcdemo.test.aspect")
@Configuration
@EnableAspectJAutoProxy  //开启AspectJ动态代理
class AspectJSpringConfig {
}
//或者
<aop:aspectj-autoproxy/>
  • 测试

/**
 * @author futao
 * Created on 2019-04-17.
 */
public class AspectJTest {
    @Test
    public void test1() {
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(AspectJSpringConfig.class);
        DivService divService = applicationContext.getBean(DivService.class);
        divService.div(1, 1);
        System.out.println(StringUtils.repeat("==", 50));
        divService.div(1, 0);
    }
}


结果


image.png

# 开发步骤以及注意事项


  1. 开发步骤
  • 定义目标方法
  • 定义切入点,切面等方法
  • 将目标类与切面类都加入Spring容器中
  • 将切面类加上@Aspect注解,表明这是一个切面类
  • 开启Spring的注解式切面@ EnableAspectJAutoProxy
  1. 注意事项
  • 目标类和切面类都需要加入到Spring容器中,交给Spring来管理。
  • 通过new 目标类的方式生成的对象不会被切面拦截。
目录
打赏
0
0
0
0
0
分享
相关文章
(工作经验)优雅实现接口权限校验控制:基于自定义注解、AOP与@ConditionalOnProperty配置开关的通用解决方案
(工作经验)优雅实现接口权限校验控制:基于自定义注解、AOP与@ConditionalOnProperty配置开关的通用解决方案
125 1
使用完全注解的方式进行AOP功能实现(@Aspect+@Configuration+@EnableAspectJAutoProxy+@ComponentScan)
本文介绍了如何使用Spring框架的注解方式实现AOP(面向切面编程)。当目标对象没有实现接口时,Spring会自动采用CGLIB库进行动态代理。文中详细解释了常用的AOP注解,如`@Aspect`、`@Pointcut`、`@Before`等,并提供了完整的示例代码,包括业务逻辑类`User`、配置类`SpringConfiguration`、切面类`LoggingAspect`以及测试类`TestAnnotationConfig`。通过这些示例,展示了如何在方法执行前后添加日志记录等切面逻辑。
544 2
使用完全注解的方式进行AOP功能实现(@Aspect+@Configuration+@EnableAspectJAutoProxy+@ComponentScan)
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
77 1
Java开发必读,谈谈对Spring IOC与AOP的理解
Spring的IOC和AOP机制通过依赖注入和横切关注点的分离,大大提高了代码的模块化和可维护性。IOC使得对象的创建和管理变得灵活可控,降低了对象之间的耦合度;AOP则通过动态代理机制实现了横切关注点的集中管理,减少了重复代码。理解和掌握这两个核心概念,是高效使用Spring框架的关键。希望本文对你深入理解Spring的IOC和AOP有所帮助。
71 0
|
4月前
|
Springboot自定义注解+aop实现redis自动清除缓存功能
通过上述步骤,我们不仅实现了一个高度灵活的缓存管理机制,还保证了代码的整洁与可维护性。自定义注解与AOP的结合,让缓存清除逻辑与业务逻辑分离,便于未来的扩展和修改。这种设计模式非常适合需要频繁更新缓存的应用场景,大大提高了开发效率和系统的响应速度。
120 2
|
5月前
Micronaut AOP与代理机制:实现应用功能增强,无需侵入式编程的秘诀
AOP(面向切面编程)能够帮助我们在不修改现有代码的前提下,为应用程序添加新的功能或行为。Micronaut框架中的AOP模块通过动态代理机制实现了这一目标。AOP将横切关注点(如日志记录、事务管理等)从业务逻辑中分离出来,提高模块化程度。在Micronaut中,带有特定注解的类会在启动时生成代理对象,在运行时拦截方法调用并执行额外逻辑。例如,可以通过创建切面类并在目标类上添加注解来记录方法调用信息,从而在不侵入原有代码的情况下增强应用功能,提高代码的可维护性和可扩展性。
107 1
什么是AOP面向切面编程?怎么简单理解?
本文介绍了面向切面编程(AOP)的基本概念和原理,解释了如何通过分离横切关注点(如日志、事务管理等)来增强代码的模块化和可维护性。AOP的核心概念包括切面、连接点、切入点、通知和织入。文章还提供了一个使用Spring AOP的简单示例,展示了如何定义和应用切面。
505 1
什么是AOP面向切面编程?怎么简单理解?
论面向方面的编程技术及其应用(AOP)
【11月更文挑战第2天】随着软件系统的规模和复杂度不断增加,传统的面向过程编程和面向对象编程(OOP)在应对横切关注点(如日志记录、事务管理、安全性检查等)时显得力不从心。面向方面的编程(Aspect-Oriented Programming,简称AOP)作为一种新的编程范式,通过将横切关注点与业务逻辑分离,提高了代码的可维护性、可重用性和可读性。本文首先概述了AOP的基本概念和技术原理,然后结合一个实际项目,详细阐述了在项目实践中使用AOP技术开发的具体步骤,最后分析了使用AOP的原因、开发过程中存在的问题及所使用的技术带来的实际应用效果。
92 5
|
5月前
Micronaut AOP与代理机制:实现应用功能增强,无需侵入式编程的秘诀
【9月更文挑战第9天】AOP(面向切面编程)通过分离横切关注点提高模块化程度,如日志记录、事务管理等。Micronaut AOP基于动态代理机制,在应用启动时为带有特定注解的类生成代理对象,实现在运行时拦截方法调用并执行额外逻辑。通过简单示例展示了如何在不修改 `CalculatorService` 类的情况下记录 `add` 方法的参数和结果,仅需添加 `@Loggable` 注解即可。这不仅提高了代码的可维护性和可扩展性,还降低了引入新错误的风险。
61 13
|
4月前
|
AOP面向切面编程
AOP面向切面编程
58 0