1.AspectJ的概念
@AspectJ类似于Java注解的普通Java类
Spring可以使用AspectJ来做切入点解析
AOP的运行时仍旧是纯的Spring AOP,对AspectJ的编译器或者织入无依赖性.
2.配置方式
注解方式 -- @Configuration
@EnableAspectJAutoProxy
任何拥有@Aspect注解的bean都将被Spring自动识别并应用
注释的类可以有方法和字段,他们也可以有切入点(pointcut),通知(Advice)和引入(introduction)声明
@Aspect注解不能够通过类路径自动检测发现,需要配合使用@Component注释或者在XML配置bean
xml文件方式
--<aop:aspectj-autoproxy/>
3.ASpectJ为编译期的AOP,检查代码并匹配连接点与切入点的代价昂贵
好的切入点包括
--选择特定类型的连接点(execution/get/set/call/handler)
--确认连接点范围(within/withincode)
--匹配上下文信息(this/target/@annotation)
4.Around advice
使用@Around注释来声明,通知方法的第一个参数必须是ProcessdingJoinPoint类型
再通知内部调用processdingjoinpoint的proceed()方法会引导至真正的方法,传入一个Object[]对象,数组中的值将被作为参数传递给方法
5. * 使用execution表达式
* 使用已经定义表达式的方法名 --@Before("pointcut()")
@AfterReturning(pointcut="implPointcut()",returning="args")
@AfterThrowing(pointcut="pointcut()",throwing="e")
@After("pointcut()")
@Pointcut("execution(* com.aspectj.impl.*Impl.*(..))")
@Pointcut("within(com.aspectj.impl.*)")
6.Advice扩展
1>给advice传递参数 -- 方法的参数可以是任何类的对象
在@before时+&&args(account,..)
定义注解传参
@Before("pointcut()&&@annotation(methodValue)")
public void beforeWithAnnotation(Methodvalue methodValue)
SpringAOp可以处理泛型类的声明和使用方法的参数
通知和切入点注解有一个额外的"argNames"属性,它可以用来指定所注解的方法的参数名
--如果第一参数时JoinPoint,ProceedingJoinPoint,JoinPoint.StaticPart,那么可以忽略它 -- -- ,argNames="bean,auditable,.."
2>Introductions
允许一个切面声明一个通知对象实现指定接口,并且提供了一个接口实现类来代表这些对象
introduction使用@DeclareParents进行注解,这个注解用来定义匹配的类型拥有一个新的parent
3>切面实例化模型 -- 高级主题
"perthis"切面通过指定@Aspect注解perthis子句实现
每个独立的service对象执行时都会创建一个切面实例
service对象的每个方法在第一次执行的时候创建切面实例,切面在service对象失效的同时失效
http://blog.csdn.net/jacxuan/article/details/53454819
@AspectJ类似于Java注解的普通Java类
Spring可以使用AspectJ来做切入点解析
AOP的运行时仍旧是纯的Spring AOP,对AspectJ的编译器或者织入无依赖性.
2.配置方式
注解方式 -- @Configuration
@EnableAspectJAutoProxy
任何拥有@Aspect注解的bean都将被Spring自动识别并应用
注释的类可以有方法和字段,他们也可以有切入点(pointcut),通知(Advice)和引入(introduction)声明
@Aspect注解不能够通过类路径自动检测发现,需要配合使用@Component注释或者在XML配置bean
xml文件方式
--<aop:aspectj-autoproxy/>
3.ASpectJ为编译期的AOP,检查代码并匹配连接点与切入点的代价昂贵
好的切入点包括
--选择特定类型的连接点(execution/get/set/call/handler)
--确认连接点范围(within/withincode)
--匹配上下文信息(this/target/@annotation)
4.Around advice
使用@Around注释来声明,通知方法的第一个参数必须是ProcessdingJoinPoint类型
再通知内部调用processdingjoinpoint的proceed()方法会引导至真正的方法,传入一个Object[]对象,数组中的值将被作为参数传递给方法
5. * 使用execution表达式
* 使用已经定义表达式的方法名 --@Before("pointcut()")
@AfterReturning(pointcut="implPointcut()",returning="args")
@AfterThrowing(pointcut="pointcut()",throwing="e")
@After("pointcut()")
@Pointcut("execution(* com.aspectj.impl.*Impl.*(..))")
@Pointcut("within(com.aspectj.impl.*)")
6.Advice扩展
1>给advice传递参数 -- 方法的参数可以是任何类的对象
在@before时+&&args(account,..)
定义注解传参
@Before("pointcut()&&@annotation(methodValue)")
public void beforeWithAnnotation(Methodvalue methodValue)
SpringAOp可以处理泛型类的声明和使用方法的参数
通知和切入点注解有一个额外的"argNames"属性,它可以用来指定所注解的方法的参数名
--如果第一参数时JoinPoint,ProceedingJoinPoint,JoinPoint.StaticPart,那么可以忽略它 -- -- ,argNames="bean,auditable,.."
2>Introductions
允许一个切面声明一个通知对象实现指定接口,并且提供了一个接口实现类来代表这些对象
introduction使用@DeclareParents进行注解,这个注解用来定义匹配的类型拥有一个新的parent
3>切面实例化模型 -- 高级主题
"perthis"切面通过指定@Aspect注解perthis子句实现
每个独立的service对象执行时都会创建一个切面实例
service对象的每个方法在第一次执行的时候创建切面实例,切面在service对象失效的同时失效
http://blog.csdn.net/jacxuan/article/details/53454819
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端