Spring AOP知识储备(基础知识)--日志打印

目录

1.AOP的概念

2.常用的动态代理技术

3.了解AOP相关术语

(1)核心概念

(2)通知分类

4.需要编写的内容

5.切点表达式的写法

6.打印日志

6.1 配置文件方式

(1)导入依赖

(2)创建目标接口和目标类(内部有切点)

(3)创建切面类(内部有增强方法)

(4)在Spring配置文件中加入织入关系(先把创建对象交给Spring)

(5)测试方法

6.2注解方式

(1)创建目标接口和目标类(内部有切点)

(2)创建切面类(内部有增强方法),并配置织入关系(这里用到通知的注解)

(3)将目标类和切面类的对象创建权交给spring,并在配置文件中开启组件扫描和AOP的自动代理(在spring配置文件上,@EnableAspectJAutoProxy表示AOP的自动代理)

(4)测试方法


1.AOP的概念

AOP:Aspect Oriented Programming,面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善。AOP是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。

AOP则利用一种称为横切的技术,剖开对象内部,并将公共行为封装到可重用模块,从而减少重复代码,降低耦合。如下图,利用横切技术,来达到降低耦合的目的。

简单的说,AOP 的作用就是保证开发者在不修改源代码的前提下,为系统中的业务组件添加某种通用功能。

2.常用的动态代理技术

  • JDK代理:基于接口的动态代理技术

  • cglib代理:基于父类的动态代理技术

3.了解AOP相关术语

(1)核心概念

  • Target(目标对象):代理的目标对象

  • Proxy(代理):一个类被AOP织入增强后,就产生一个结果代理类

  • Joinpoint(连接点):所谓连接点是指那些被拦截到的点。在spring,,这些点指的是方法,因为spring只支持方法类型的连接点

  • Pointcut(切入点):所谓切入点是指我们要对哪些Joinpoint进行拦截的定义;定义切面插入在哪些方法上,确定切面使用范围

  • Advice(通知/增强):所谓通知是指拦截Joinpoint之后所要做的事情就是通知

  • Aspect(切面):指封装横切到系统功能的类,包含通知和切点

  • Weaving (织入):是指把增强应用到目标对象来创建新的代理对象的过程。spring采用动态代理织入,而AspectJ采用编译期织入和类装载期织入

(2)通知分类

名称标签注解说明
前置通知<aop:before>@Before用于配置前置通知。指定增强的方法在切入点方法之前执行
后置返回通知<aop:AfterReturning>@AfterReturning用于配置后置通知。指定增强的方法在切入点方法之后执行,并且方法内部不能抛出异常
环绕通知<aop:Around>@Around用于配置环绕通知。指定增强的方法在切入点方法之前和之后都执行
异常抛出通知<aop:AfterThrowing>@AfterThrowing用于配置异常抛出通知。指定增强的方法在出现异常时执行
后置通知<aop:After>@After用于配置最终通知。无论增强方式执行是否有异常都会执行

注意:环绕通知的方法里我们通过ProceedingJoinPoint参数来获取连接点信息,其余四种通知的方法里面我们可以通过JoinPoint参数获取连接点信息,比如参数信息等,方便进行处理

4.需要编写的内容

  • 编写核心业务代码(目标类的目标方法)

  • 编写切面类,切面类中有通知(增强功能方法)

  • 在配置文件中,配置织入关系,即将哪些通知与哪些连接点进行结合

5.切点表达式的写法

语法:

                execution([修饰符]返回值类型包名.类名.方法名(参数))

  • 访问修饰符可以省略

  • 返回值类型、包名、类名、方法名可以使用星号*代表任意

  • 包名与类名之间一个点.代表当前包下的类,两个点..表示当前包及其子包下的类

  • 参数列表可以使用两个点..表示任意个数,任意类型的参数列表

例如:

6.打印日志

6.1 配置文件方式

(1)导入依赖

(2)创建目标接口和目标类(内部有切点)

(3)创建切面类(内部有增强方法)

(4)在Spring配置文件中加入织入关系(先把创建对象交给Spring)

当然在调用方法时记录传递参数、返回值以及执行结束时间可以用参数传参

那就需要修改配置文件

(5)测试方法

6.2注解方式

(1)创建目标接口和目标类(内部有切点)

        在目标类上加上注解(例如@Service)

(2)创建切面类(内部有增强方法),并配置织入关系(这里用到通知的注解)

第一种

也有第二种用法

但目前我用的更多的是第一种

(3)将目标类和切面类的对象创建权交给spring,并在配置文件中开启组件扫描和AOP的自动代理(在spring配置文件上,@EnableAspectJAutoProxy表示AOP的自动代理)

(4)测试方法

总之,AOP的用法就是在不改变源代码的情况下,为系统中的业务组件添加某种通用功能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值