Spring AOP的实现原理

3 篇文章 0 订阅
订阅专栏

目录

前言

一、Spring的aop的概念

AOP是什么

横切关注点

AOP的特点

AOP带来的好处

二、AOP的实现原理

1、基于代理的实现

2、切点

3、切面

4、通知

5、织入

三、Spring AOP concepts(AOP术语)

思维导图

【术语】:

适配器

四、常用通知

前置通知(Before advice):

​编辑 后置通知(After returning advice):

​编辑 环绕通知(Around advice):

异常通知(After throwing advice): 

 过滤通知(Filtering Notifications advice):


前言

Spring的核心特性之一就是 面向切面编程(AOP),它允许程序员通过定义切点和切面,将横切关注点与业务逻辑分离,并在运行期动态将切面织入到目标对象的方法执行过程中。

一、Spring的aop的概念

AOP是什么

  1. AOP(面向切面编程)是一种编程范式,用于将横切关注点与业务逻辑分离。横切关注点是指在应用程序中多个模块或组件中重复出现的功能,如日志记录、事务管理、安全性等。通过AOP,可以将这些横切关注点抽象出来,以便在需要的地方进行重用。

  2. AOP(面向切面编程)是一种编程范式,用于将横切关注点与业务逻辑分离。横切关注点是指在应用程序中多个模块或组件中重复出现的功能,如日志记录、事务管理、安全性等。通过AOP,可以将这些横切关注点抽象出来,以便在需要的地方进行重用。

横切关注点

  • 与业务主要流程关系不大的部分
  • 经常发生在核心关注点的多处,而各处都是基本相似的功能
  • 如权限认证、日志、事务处理

AOP的特点

  1. 横向切面:AOP 的主要目的是解决横向切面的问题,即对多个对象的同种操作进行统一的处理,比如日志记录、性能统计、事务处理等。

  2. 切面集中处理:AOP 将切面的逻辑从业务逻辑中分离出来,实现了切面的集中处理。这样可以更好地实现代码的模块化和重用。

  3. 低侵入性:AOP 对原有业务逻辑的侵入性较小,只需要在切面中进行逻辑编写,不需要对原有类进行大量修改,提高了代码的可维护性和可扩展性。

  4. 动态代理:AOP 通过动态代理实现了切面的实现,在运行期间动态生成代理对象,实现了透明化的切面处理。

  5. 面向接口编程:AOP 一般采用面向接口编程的方式,使应用与具体实现相分离,提高了系统的可扩展性和可维护性。

  6. 与OOP关联性弱:AOP 与 OOP(面向对象编程)有较弱的关联性,可以与任何编程语言和编程模型兼容,提高了代码的通用性和移植性。

AOP带来的好处

  • 模块化:通过将横切关注点与业务逻辑分离,可以提高代码的模块化和可维护性。
  • 重用性:可以将横切关注点作为独立的模块进行重用,减少了代码的重复编写。
  • 解耦性:AOP可以将横切关注点与业务逻辑解耦,使得代码更加清晰和可读。
  • 灵活性:通过AOP,可以在不修改原始代码的情况下,动态地添加、修改或删除横切关注点。
  • 可维护性:将横切关注点抽象出来,使得对其进行修改或调整更加方便和可控。

二、AOP的实现原理

1、基于代理的实现

Spring使用动态代理技术来实现AOP。当一个bean被代理时,Spring会根据该bean实现的接口或父类创建一个代理对象,然后拦截目标方法的调用,并在目标方法的前后加入额外的行为,从而实现AOP。

2、切点

切点是AOP中的重要概念,它定义了需要被切入的连接点,即目标对象中哪些方法需要被拦截。Spring AOP中,切点可以使用AspectJ切点表达式来定义。AspectJ切点表达式可以匹配目标对象的方法,由此确定了需要被织入增强逻辑的方法,是AOP执行的入口。、

3、切面

切面定义了横切逻辑的实现,它是一个包含了advice和pointcut的类。Advice是指增强逻辑,它定义了需要织入目标方法前、后或者代替目标方法执行的代码,可以使用before、after、around等方式实现;Pointcut是指切点,它定义了对哪些方法进行拦截。

4、通知

通知是切面中的实际增强逻辑,它是指在特定的切点上执行的具体操作,Spring AOP中常见的Advice有before、after、after-returning、after-throwing和around等。

5、织入

织入是指将切面应用到目标对象的过程。Spring AOP支持三种织入方式,分别是编译时织入、类加载时织入和运行时织入。

在运行时织入时,Spring AOP使用动态代理实现,即在目标对象的方法执行的前、后或者代替目标方法执行增加了额外的逻辑。而JDK动态代理的机制是利用反射来动态生成代理类,这个代理类实现了需要代理的接口,并在InvocationHandler的中的回调方法中执行目标方法的前、后或者代替目标方法执行额外的逻辑。

三、Spring AOP concepts(AOP术语)

思维导图

【术语】:

切面(Aspect):
一个关注点的模块化,这个关注点可能会横切多个对象。
事务管理是 J2EE 应用中一个关于横切关注点的很好列子。
在 Spring AOP 中,切面可以使用基于模式或者基于 @Aspect 注解的方式来实现。

连接点(Joinpoint):
在程序执行过程中某个特定的点,比如某方法调用的时候或者处理异常的时候。
在 Spring AOP 中,一个连接点总是表示一个方法的执行。

切入点(Pointcut):
匹配连接点的断言。通知和一个切入点表达式关联,并在满足这个切入点的连接点上运行(例如:当执行某个特定名称的方法时)。
切入点表达式如何和连接点匹配是 AOP 的核心:Spring 缺省使用 Aspect 切入点语法。

引入(Introduction):
用来给一个类型声明额外的方法或属性(也被称为连接类型声明(inter-type declaration))
Spring 允许引入新的接口(以及一个对应的实现)到任何被代理的对象。例如,可以使用引入来使一个 bean 实现 isModified 接口,以便简化缓存机制。

目标对象(Target Object):
被一个或者多个切面所通知的对象,也被称为通知(advised)对象。
既然 Spring AOP 是通过运行时代理实现的。这个对象永远是一个被代理(proxied)对象。

AOP 代理(AOP Proxy):
AOP 框架创建的对象,用来实现切面契约(例如,通知方法执行等等)。
在 Spring 中,AOP 代理可以是 JDK 动态代理或者 CGLIB 代理。

织入(Weaving):
把切面连接到其它的应用程序类型或者对象上,并创建一个被通知的对象。这些可以在编译时(例如使用 AspectJ 编译器),类加载时和运行时完成。Spring 和其他纯 Java AOP 框架一样,在运行时完成织入。

通知(Advice):
在切面的某个特定的连接点上执行的动作。其中包括“around”、“before” 和 “after” 等不同类型的通知。
许多 AOP 框架(包括 Spring)都是以拦截器做通知模型,并维护一个以连接点为中心的拦截器链。

适配器

适配器(Adapter)是一种结构型设计模式,用于将两个不兼容的接口协同工作。适配器模式的核心思想是解决新旧接口之间的兼容性问题,让不同接口之间能够无缝衔接。

作用:把一个接口(源接口)转换成另一个接口(目标接口),以满足目标接口的需求。适配器模式一般分为类适配器和对象适配器两种实现方式。

适配器模式中的三个角色:

  1. 目标接口(Target):定义客户端使用的与特定领域相关的接口,客户端只能看到这个接口而不知道具体实现。

  2. 源接口(Adaptee):需要被适配的接口,即客户端需要调用的接口,但由于与客户端的接口不兼容而无法直接使用。

  3. 适配器(Adapter):用于将源接口转换成目标接口的中间件,把客户端的请求传递给适配者,完成客户端需要的功能。

适配器模式常用于系统升级或接口变更时,通过适配器来实现旧接口向新接口的转换,以保证系统的兼容性和稳定性。

四、常用通知

定义一个接口

package com.ctb.aop.biz;

public interface IBookBiz {
	// 购书
	public boolean buy(String userName, String bookName, Double price);

	// 发表书评
	public void comment(String userName, String comments);
}

实现接口

package com.ctb.aop.biz.impl;

import com.ctb.aop.biz.IBookBiz;
import com.ctb.aop.exception.PriceException;
public class BookBizImpl implements IBookBiz {

	public BookBizImpl() {
		super();
	}

	public boolean buy(String userName, String bookName, Double price) {
		// 通过控制台的输出方式模拟购书
		if (null == price || price <= 0) {
			throw new PriceException("book price exception");
		}
		System.out.println(userName + " buy " + bookName + ", spend " + price);
		return true;
	}

	public void comment(String userName, String comments) {
		// 通过控制台的输出方式模拟发表书评
		System.out.println(userName + " say:" + comments);
	}

}

 异常处理类

package com.ctb.aop.exception;

public class PriceException extends RuntimeException {

	public PriceException() {
		super();
	}

	public PriceException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
		super(message, cause, enableSuppression, writableStackTrace);
	}

	public PriceException(String message, Throwable cause) {
		super(message, cause);
	}

	public PriceException(String message) {
		super(message);
	}

	public PriceException(Throwable cause) {
		super(cause);
	}
	
}

测试类

package com.ctb.aop.demo;

import com.ctb.aop.biz.IBookBiz;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/**
 * @author 彪
 * @remark
 * @create  2023-08-17 15:54
 */
public class Demo1 {

    public static void main(String[] args) {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring_context.xml");
//        IBookBiz bookBiz= (IBookBiz) context.getBean("bookBiz");
        IBookBiz bookBiz= (IBookBiz) context.getBean("bookProxy");
        bookBiz.buy("死仔","死亡药剂",9.9d);
        bookBiz.comment("死仔","爽歪歪");
    }
}

前置通知(Before advice):

@Before
在某连接点之前执行的通知,但这个通知不能阻止了连接点之前的执行流程(除非它抛出一个异常)。

实现前置通知接口

package com.ctb.aop.advice;

import org.springframework.aop.MethodBeforeAdvice;

import java.lang.reflect.Method;
import java.util.Arrays;

/**
 * 买书、评论前加系统日志
 * @author biao
 *
 */
public class MyMethodBeforeAdvice implements MethodBeforeAdvice {

	@Override
	public void before(Method arg0, Object[] arg1, Object arg2) throws Throwable {
//		在这里,可以获取到目标类的全路径及方法及方法参数,然后就可以将他们写到日志表里去
		String target = arg2.getClass().getName();
		String methodName = arg0.getName();
		String args = Arrays.toString(arg1);
		System.out.println("【前置通知:系统日志】:"+target+"."+methodName+"("+args+")被调用了");
	}

}

 spring_context.xml

 <!--目标对象-->
    <bean class="com.ctb.aop.biz.impl.BookBizImpl" id="bookBiz"></bean>
    <!--通知-->
    <bean class="com.ctb.aop.advice.MyMethodBeforeAdvice" id="methodBeforeAdvice"></bean>
    
    <!-- 代理   -->
    <bean class="org.springframework.aop.framework.ProxyFactoryBean" id="bookProxy">
        <!--配置目标对象-->
    <property name="target" ref="bookBiz"></property>
        <!--配置代理的接口,目标对象的接口         
        -->
        <property name="proxyInterfaces">
                  <list>
                      <value>com.ctb.aop.biz.IBookBiz</value>
                  </list>
        </property>
        <!--配置通知-->
        <property name="interceptorNames">
            <list>
                <value>methodBeforeAdvice</value>
            </list>
        </property>



    </bean>

测试结果

 后置通知(After returning advice):

@After-returning
在某连接点正常完成后执行的通知,例如,一个方法么有抛出任何异常,正常返回。

实现后置通知接口

package com.ctb.aop.advice;

import org.springframework.aop.AfterReturningAdvice;

import java.lang.reflect.Method;
import java.util.Arrays;

/**
 * 买书返利
 * @author biao
 *
 */
public class MyAfterReturningAdvice implements AfterReturningAdvice {

	@Override
	public void afterReturning(Object arg0, Method arg1, Object[] arg2, Object arg3) throws Throwable {
		String target = arg3.getClass().getName();
		String methodName = arg1.getName();
		String args = Arrays.toString(arg2);
		System.out.println("【后置通知:买书返利】:"+target+"."+methodName+"("+args+")被调用了,"+"该方法被调用后的返回值为:"+arg0);
	

	}

}

spring_context.xml

    <!--目标对象-->
    <bean class="com.ctb.aop.biz.impl.BookBizImpl" id="bookBiz"></bean>
    <!--通知-->
    <bean class="com.ctb.aop.advice.MyMethodBeforeAdvice" id="methodBeforeAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyAfterReturningAdvice" id="afterReturningAdvice"></bean>
    
    <!-- 代理   -->
    <bean class="org.springframework.aop.framework.ProxyFactoryBean" id="bookProxy">
        <!--配置目标对象-->
    <property name="target" ref="bookBiz"></property>
        <!--配置代理的接口,目标对象的接口          
        -->
        <property name="proxyInterfaces">
                  <list>
                      <value>com.ctb.aop.biz.IBookBiz</value>
                  </list>
        </property>
        <!--配置通知-->
        <property name="interceptorNames">
            <list>
                <value>methodBeforeAdvice</value>
                <value>afterReturningAdvice</value>
            </list>
        </property>



    </bean>

 测试结果

 环绕通知(Around advice):

@Around
包围一个连接点的通知,如方法调用,这是最强大的一种通知类型。

实现环绕通知接口

package com.ctb.aop.advice;

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

import java.util.Arrays;

/**
 * 环绕通知
 * 	包含了前置和后置通知
 * 
 * @author biao
 *
 */
public class MyMethodInterceptor implements MethodInterceptor {

	@Override
	public Object invoke(MethodInvocation arg0) throws Throwable {
		String target = arg0.getThis().getClass().getName();
		String methodName = arg0.getMethod().getName();
		String args = Arrays.toString(arg0.getArguments());
		System.out.println("【环绕通知调用前:】:"+target+"."+methodName+"("+args+")被调用了");
//		arg0.proceed()就是目标对象的方法
		Object proceed = arg0.proceed();
		System.out.println("【环绕通知调用后:】:该方法被调用后的返回值为:"+proceed);
		return proceed;
	}

}

spring_context.xml

    <!--目标对象-->
    <bean class="com.ctb.aop.biz.impl.BookBizImpl" id="bookBiz"></bean>
    <!--通知-->
    <bean class="com.ctb.aop.advice.MyMethodBeforeAdvice" id="methodBeforeAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyAfterReturningAdvice" id="afterReturningAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyMethodInterceptor" id="methodInterceptor"></bean>
   
    <!-- 代理   -->
    <bean class="org.springframework.aop.framework.ProxyFactoryBean" id="bookProxy">
        <!--配置目标对象-->
    <property name="target" ref="bookBiz"></property>
        <!--配置代理的接口,目标对象的接口          动态代理中的jdk代理与cglib代理有什么区别,代理模式,是什么样的,什么是动态代理,什么是静态代理
                                                 在编码中是怎么用到cglib代理和jdk代理的,在什么场景下用的
        -->
        <property name="proxyInterfaces">
                  <list>
                      <value>com.ctb.aop.biz.IBookBiz</value>
                  </list>
        </property>
        <!--配置通知-->
        <property name="interceptorNames">
            <list>
                <value>methodBeforeAdvice</value>
                <value>afterReturningAdvice</value>
                <value>methodInterceptor</value>
            </list>
        </property>
        
    </bean>

测试结果

异常通知(After throwing advice): 

@After-throwing
在方法抛出异常退出时执行的通知。

实现异常通知接口

package com.ctb.aop.advice;

import org.springframework.aop.ThrowsAdvice;

import com.ctb.aop.exception.PriceException;

/**
 * 出现异常执行系统提示,然后进行处理。价格异常为例
 * @author biao
 *
 */
public class MyThrowsAdvice implements ThrowsAdvice {
	public void afterThrowing(PriceException ex) {
		System.out.println("【异常通知】:当价格发生异常,那么执行此处代码块!!!");
	}
}

spring_context.xml

    <!--目标对象-->
    <bean class="com.ctb.aop.biz.impl.BookBizImpl" id="bookBiz"></bean>
    <!--通知-->
    <bean class="com.ctb.aop.advice.MyMethodBeforeAdvice" id="methodBeforeAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyAfterReturningAdvice" id="afterReturningAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyMethodInterceptor" id="methodInterceptor"></bean>
    <bean class="com.ctb.aop.advice.MyThrowsAdvice" id="myThrowsAdvice"></bean>
   
    <!-- 代理   -->
    <bean class="org.springframework.aop.framework.ProxyFactoryBean" id="bookProxy">
        <!--配置目标对象-->
    <property name="target" ref="bookBiz"></property>
        <!--配置代理的接口,目标对象的接口          动态代理中的jdk代理与cglib代理有什么区别,代理模式,是什么样的,什么是动态代理,什么是静态代理
                                                 在编码中是怎么用到cglib代理和jdk代理的,在什么场景下用的
        -->
        <property name="proxyInterfaces">
                  <list>
                      <value>com.ctb.aop.biz.IBookBiz</value>
                  </list>
        </property>
        <!--配置通知-->
        <property name="interceptorNames">
            <list>
                <value>methodBeforeAdvice</value>
                <value>afterReturningAdvice</value>
                <value>methodInterceptor</value>
                <value>myThrowsAdvice</value>
            </list>
        </property>



    </bean>

我们将测试类中的价格改成负数,进行异常测试

测试结果

 过滤通知(Filtering Notifications advice):

@Filtering Notifications 

根据一定的条件对通知进行筛选和过滤,只选择符合条件的通知进行处理或显示。

spring_context.xml

 <!--目标对象-->
    <bean class="com.ctb.aop.biz.impl.BookBizImpl" id="bookBiz"></bean>
    <!--通知-->
    <bean class="com.ctb.aop.advice.MyMethodBeforeAdvice" id="methodBeforeAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyAfterReturningAdvice" id="afterReturningAdvice"></bean>
    <bean class="com.ctb.aop.advice.MyMethodInterceptor" id="methodInterceptor"></bean>
    <bean class="com.ctb.aop.advice.MyThrowsAdvice" id="myThrowsAdvice"></bean>
    <bean class="org.springframework.aop.support.RegexpMethodPointcutAdvisor" id="regexpMethodPointcutAdvisor">
        <property name="advice" ref="afterReturningAdvice"></property>
        <property name="pattern" value=".*buy"></property>

    </bean>
    <!-- 代理   -->
    <bean class="org.springframework.aop.framework.ProxyFactoryBean" id="bookProxy">
        <!--配置目标对象-->
    <property name="target" ref="bookBiz"></property>
        <!--配置代理的接口,目标对象的接口         
        -->
        <property name="proxyInterfaces">
                  <list>
                      <value>com.ctb.aop.biz.IBookBiz</value>
                  </list>
        </property>
        <!--配置通知-->
        <property name="interceptorNames">
            <list>
                <value>methodBeforeAdvice</value>
<!--                <value>afterReturningAdvice</value>-->
                <value>regexpMethodPointcutAdvisor</value>
                <value>methodInterceptor</value>
                <value>myThrowsAdvice</value>
            </list>
        </property>



    </bean>

在过滤通知中 ,我们可以在过滤通知配置中设置一些正则表达式,

减少不必要的干扰,提高工作效率,同时确保不会错过重要的通知。

测试结果

 spring aop底层原理到这就结束啦,希望各位大佬能一键三连哦!!

spring aop实现原理
03-15
NULL 博文链接:https://zhang-yingjie-qq-com.iteye.com/blog/319927
Spring AOP实现原理解析
08-28
主要为大家详细介绍了Spring AOP实现原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Spring实现AOP的三种方式
七一
08-16 1232
1、什么是AOP AOP(Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。 2、AOPSpring中的作用 横切关注点:跨越应用程序多个模块的方法或功能。即是,与我们业务逻辑无
Spring API 接口和自定义类来实现AOPSpring学习笔记十)
最新发布
weixin_59096327的博客
03-30 468
全称是 Aspect Oriented Programming 即:面向切面编程。是OOP(面向对象编程)的延续,也是Spring框架中的一个重要内容,是函数式编程的一种衍生泛型。简单的说他就是把我们程序重复的代码抽取出来,在需要执行的时候使用动态代理技术在不修改源码的基础上,对我们的已有方法进行增强。AOC在Spring中的作用创建自定义类和方法System.out.println("====切面之前执行====");System.out.println("====切面之后执行====");
注解、原生Spring、SchemaBased三种方式实现AOP【附详细案例】
qq_53317005的博客
06-05 4104
使用注解、原生Spring、SchemaBased三种方法实现AOP
Spring实现AOP的三种方式
z_ssyy的博客
04-25 283
①自定义被切入类/** 自定义类* */System.out.println("方法执行前前前前前前前前前前");System.out.println("方法执行后后后后后后后后后后");
spring实现AOP
Java学习博客
02-13 816
spring的核心是IOC(控制反转)和AOP(面向切面编程)。AOP面向切面编程是通过预编译方式和运行期间动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。本文记录了两种开发AOP编程的方式。
深入浅析Springaop实现原理
09-02
AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Oriented Programing,面向对象编程)的补充和完善。本文给大家介绍Springaop实现原理,感兴趣的朋友一起学习吧
Java框架篇?spring AOP 实现原理
12-22
什么是AOP  AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Oriented Programing,面向对象编程)的补充和完善。OOP引入封装、继承和多态性等概念来建立一种对象层次结构,用以模拟公共...
Spring AOP实现原理详解及实例
10-19
主要介绍了Spring AOP实现原理详解及实例的相关资料,需要的朋友可以参考下
Spring实现AOP的4种方式
10-25
Spring实现AOP有很多方式,这里总结了四种,有基于代理的实现方式,也有基于AspectJ 的注解方式,还有基于AOP标签的配置
spring系列】之17:spring aop工程流程
licwzy的博客
10-20 288
AOP:【动态代理】 * 指在程序运行期间动态的将某段代码切入到指定方法指定位置进行运行的编程方式; * * 1、导入aop模块;Spring AOP:(spring-aspects) * 2、定义一个业务逻辑类(MathCalculator);在业务逻辑运行的时候将日志进行打印(方法之前、方法运行结束、方法出现异常,xxx) * 3、定义一个日志切面类(LogAspects):切面类里面的方法需要动态感知MathCalculator.div运行到哪里然后执行; * 通知方法: * .
使用Spring实现Aop三种方法
vengu733的博客
08-05 3137
** 方式一 :使用spring的AP接口 方式二 : 自定义来实现AOP (主要是切面定义) 方式三 :使用注解实现AOP **使用AOP 植入 ,需要导入依赖包aspectj 方式一 :使用spring的AP接口 定义uservice接口 接口实现类userviceImpl 创建要做代理 为uservice 添加日志 的log类 创建afterlog 类 ben.xml 创建测试: div 自定义一个类 bean.xml 测试结果: 分析: 创建annotation类 bean.xml 测试
Spring AOP实现过程
进击的豌豆的博客
07-14 3836
原文:Spring AOP实现过程aop 的作用是在书写上将辅助业务逻辑从主业务的逻辑中拆出来,实现主业务和辅助业务的,但在执行主业务逻辑的时候,辅助业逻辑业也会执行。从而保证拆前拆后功能不变。那辅助业务拆出来放在哪里?辅助业务封装在切面中,所以 。什么是切面?切面就是一个类,并且被 注释。辅助业务在切面的哪里?辅助业务封装在切面的方法里,不同的方法封装不同的辅助业务逻辑。切面中的方法是怎么触发的呢?给封装辅助业务逻辑所在的方法标注 其中一个或几个注解。这样当主业务方法执行时,辅助业务的逻辑所在的方法就
Spring AOP的三种实现方式
热门推荐
BAI20010904的博客
01-14 1万+
目录 一、什么是AOP 二、Spring AOP的三种实现方式 1.通过Spring API实现AOP (1)编写业务接口和实现类 (2)编写增强类,并实现Spring API相关接口的方法 (3)在resource目录下新建applicationContext文件,实现java类的创建和aop的织入 (4)编写测试类 2.通过自定义类来实现(推荐) (1)自定义切入类 (2)去spring中配置 (3)编写测试类 3.使用注解实现 (1)自定义增强类(注解实现) (2)..
Spring框架的AOP实现原理
qq_59510147的博客
11-20 1850
AOP:面向切面编程,是将那些与业务无关(比如有事务处理,日志管理,权限控制等),但要为业务模块共同调用的逻辑封装成一个可重用的模块,这个模块被称为切面,便于减少系统的重复代码,降低模块间的耦合度,有利于未来的可拓展性和可维护性。另一个为Proxy类,我们可以通过这个类的newProxyInstance()方法,返回一个代理对象,生成的代理类实现了原来类的所有接口,然后对这些接口进行代理,通过代理对象调用这些方法,底层通过反射来调用我们实现的invoke()方法。此通知可以在方法调用前后完成自定义的行为。
Spring系列之AOP实现的两种方式
u013733643的博客
04-08 2683
AOP常用的实现方式有两种,一种是采用声明的方式来实现(基于XML),一种是采用注解的方式来实现(基于AspectJ)。 首先复习下AOP中一些比较重要的概念: Joinpoint(连接点):程序执行时的某个特定的点,在Spring中就是某一个方法的执行 。Pointcut(切点):说的通俗点,springAOP的切点就是指一些方法的集合,而这些方法是需要被增强、被代理的。一般都是按照一定的约定规则来表示的,如正则表达式等。切点是由一类连接点组成。Advice(通知):还是说的通俗点,就是在指定切点上
springaop实现原理
05-10
Spring AOP实现原理主要是基于动态代理,它通过代理对象来控制访问目标对象的过程。当我们在应用中使用AOP时,Spring会在运行时动态地创建一个代理对象,该代理对象包含了目标对象的所有方法,并且可以在目标对象的方法执行前后加入额外的逻辑。 Spring AOP实现过程分为以下几步: 1.定义切点:指定在哪些方法上应用AOP。 2.定义通知:在方法执行前、后或出现异常时执行的代码。 3.创建代理对象:Spring使用JDK动态代理或CGLib动态代理技术创建代理对象。 4.代理对象调用目标对象:代理对象拦截目标对象的方法调用,并在执行通知之后再调用目标对象的方法。 在实际应用中,我们可以通过配置文件或注解的方式来定义切点和通知,Spring会根据配置自动生成代理对象。 总之,Spring AOP实现原理主要是基于动态代理和切面编程思想,通过代理对象控制访问目标对象的过程,并在方法执行前后加入额外的逻辑,实现了面向切面编程的目的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
写文章

热门文章

  • Java反射详解 20240
  • html动态爱心代码【一】(附源码) 12911
  • html动态爱心代码【三】(附源码) 6579
  • Set集合详解 6407
  • 安装虚拟机(VMware)保姆级教程及配置虚拟网络编辑器和安装WindowsServer以及宿主机访问虚拟机和配置服务器环境 5833

分类专栏

  • aliyun 2篇
  • RabbitMQ 1篇
  • Docker 2篇
  • OAuth2.0 1篇
  • Git 3篇
  • Redis 3篇
  • Linux操作系统 5篇
  • 小程序 7篇
  • Vue+Element UI 11篇
  • SpringMVC 7篇
  • MyBatis 5篇
  • 爱心 5篇
  • Spring 3篇
  • IDEA 1篇
  • layui 4篇
  • maven 1篇
  • Java EE 2篇
  • MySQL 4篇
  • JavaScript 2篇
  • 游戏 2篇

最新评论

  • html动态爱心代码【一】(附源码)

    孤留光乩: 斯沃看下什么问题再详细说明表情包

  • html动态爱心代码【一】(附源码)

    2301_80527644: 博主大大为什么我的没有那个大大的爱心

  • 基于Java的连连看游戏设计与实现

    孤留光乩: 你可以分别去设置图片和窗口的大小

  • 基于Java的连连看游戏设计与实现

    孤留光乩: 你在你的工程目录下建一个放图片资源的就可以了,通过图标的方式进行引入的

  • html动态爱心代码【四】(附源码)

    孤留光乩: 截图私我看一下

您愿意向朋友推荐“博客详情页”吗?

  • 强烈不推荐
  • 不推荐
  • 一般般
  • 推荐
  • 强烈推荐
提交

最新文章

  • 使用阿里云OSS实现视频上传功能
  • 阿里云OSS文件上传和下载完整指南
  • RabbitMQ交换机详解
2024年5篇
2023年81篇

目录

目录

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值

深圳SEO优化公司南充网络营销公司伊犁优秀网站设计本溪网站制作设计推荐怀化百度关键词包年推广多少钱上海网站优化按天计费报价湖州百度爱采购遂宁网络推广哪家好民治外贸网站设计公司宜宾企业网站建设朔州seo网站推广多少钱清远关键词排名包年推广公司驻马店seo排名推荐雅安百度爱采购价格黄山网页设计报价塔城百度关键词包年推广报价珠海百度关键词包年推广推荐延边企业网站制作价格淮北网站优化排名价格大理外贸网站制作哪家好辽阳品牌网站设计价格深圳阿里店铺运营公司淮北SEO按天收费推荐盐田seo哪家好那曲模板制作公司张掖网站制作设计推荐长沙外贸网站设计推荐松岗网站优化排名多少钱宜春企业网站改版推荐济南网站建设保山网站优化按天扣费价格歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化