Java AOP 代码实践

主图==========

目录


文章所属专区 日积月累


1.前言

在Spring AOP(面向切面编程)中,切面和切点是两个关键的概念。切面是一个特殊的类,它负责横切关注点的处理,即那些在多个业务关注点中都需要重复出现的功能,如事务管理、安全检查、日志记录等。切点则是一个应用执行过程中能够插入切面的点,可以是调用方法时、抛出异常时、甚至修改字段时。

2.AOP术语

2.1 切面(Aspect)

可以理解为一个规范的类,可以视作一个拦截器,可以定义被拦截的方法以及拦截执行前后的操作。

2.2 通知(Advice)

通知就是切面中的方法有五种类型
1.before :前置通知,在目标方法调用之前通知的功能
2.after:后置通知, 在目标方法调用之后通知的功能,不会关心方法的输出时扫描,即使是异常
3.afterReturning:返回通知,在目标方法成功调用之后调用通知
4.afterThrowing:异常通知,在目标方法抛出异常之后调用通知
5.around:环绕通知,通知包裹了被调整的方法,在被通知的方法调用之前和之后执行自定义的行为

在这里插入图片描述

在这里插入图片描述

2.3 引入

引入允许我们向现有的类添加新方法或属性。在不改变代码的情况下增强优化代码。

2.4 切点

告诉Spring AOP什么时候启动拦截器 并编织入对应的流程中。

2.3 连接点

连接点对应的是具体需要拦截的对象,比如通过切点的正则表达式去判断哪些方法是连接点,从而植入对应的调整。

2.3 织入

织入是一个生成代理对象,并且将切面内容放入到流程中的过程,它的实现方式就是动态代理。
在这里插入图片描述

3.代码实现

通过注解实现日志记录

3.1 EnableLog类

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
/**
 * 定义注解 为成员value设置默认值““
 */
public @interface EnableLog {
   
    
    String value() default "";
}

3.2 LogAspect类

@Aspect
@Component
@Slf4j
public class LogAspect {
   
    //获取一个日志实例,命名为LogAspect,在日志输出打印出日志所属的类
    private static final Logger logger = LoggerFactory.getLogger(LogAspect.class);
 

    //定义注解切点 带有@EnableLog 注解的方法将被拦截
    
  • 25
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

顶子哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值