AOP简介

简介: AOP简介

在这里插入图片描述

✨博客主页:👉不会压弯的小飞侠
✨欢迎关注:👉点赞👍收藏⭐留言✒
✨系列专栏:👉spring专栏
✨如果觉得博主的文章还不错的话,请三连支持一下博主。
✨欢迎大佬指正,一起学习!一起加油!


✨什么是AOP

AOP(Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

✨AOP概念

Spring的AOP实现底层就是对上面的动态代理的代码进行了封装,封装后我们只需要对需要关注的部分进行代码编写,并通过配置的方式完成指定目标的方法增强。

  • 常用的术语如下:
  • Target(目标对象)︰代理的目标对象
  • Proxy(代理):一个类被AOP织入增强后,就产生一个结果代理类
  • Joinpoint(连接点)︰所谓连接点是指那些被拦截到的点。在spring中,这些点指的是方法,因为spring只支持方法类型的连接点
  • Pointcut(切入点)∶所谓切入点是指我们要对哪些Joinpoint进行拦截的定义
  • Advice (通知/增强)∶所谓通知是指拦截到Joinpoint之后所要做的事情就是通知
  • Aspect(切面):是切入点和通知(引介)的结合
  • Weaving (织入)∶是指把增强应用到目标对象来创建新的代理对象的过程。spring采用动态代理织入,而Aspect - 采用编译期织入和类装载期织入

✨动态代理

Spring中的AOP是基于动态代理实现的,即 JDK动态代理和Cglib动态代理。

  • 常用的动态代理技术

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

✨JDK动态代理

JDK代理:基于接口的动态代理技术。
案例:

✨TargetInterface

package com.study.proxy.jdk;

public interface TargetInterface {
    void save();
}

✨Target

package com.study.proxy.jdk.impl;

import com.study.proxy.jdk.TargetInterface;

public class Target implements TargetInterface {
    public void save() {
        System.out.println("TargetImpl....");
    }
}

✨Advice

package com.study.proxy.jdk;

public class Advice {
    public void before(){
        System.out.println("前置增强....");
    }
    public void after(){
        System.out.println("后置增强....");
    }
}

✨ProxyTest

package com.study.proxy.jdk;

import com.study.proxy.jdk.impl.Target;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class ProxyTest  {
    public static void main(String[] args) {
        //目标对象
       final Target target=new Target();
       //增强对象
        final Advice advice=new Advice();
        TargetInterface proxy= (TargetInterface) Proxy.newProxyInstance(
                target.getClass().getClassLoader(), //目标对象加载器
                target.getClass().getInterfaces(),  //目标对象相同的接口字节码对象数组
                new InvocationHandler() {
                    //调用代理对象的任何方法,实质执行的都是invoke方法
                    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                        //前置增强
                        advice.before();
                        Object invoke = method.invoke(target, args);
                        //后置增强
                        advice.after();
                        return invoke;
                    }
                }
        );
        //调用代理对象的方法
        proxy.save();

    }
}
/*
前置增强....
TargetImpl....
后置增强....
 */

✨Cglib动态代理

Cglib代理:基于父类的动态代理技术。
案例:

✨Target

package com.study.proxy.cglib;

public class Target {
    public void save() {
        System.out.println("TargetImpl....");
    }
}

✨Advice

package com.study.proxy.cglib;

public class Advice {
    public void before(){
        System.out.println("前置增强....");
    }
    public void after(){
        System.out.println("后置增强....");
    }
}

✨Proxy

package com.study.proxy.cglib;

import org.springframework.cglib.proxy.Enhancer;
import org.springframework.cglib.proxy.MethodInterceptor;
import org.springframework.cglib.proxy.MethodProxy;

import java.lang.reflect.Method;

public class ProxyTest  {
    public static void main(final String[] args) {
        //目标对象
       final Target target=new Target();
       //增强对象
        final Advice advice=new Advice();

        //调用代理对象的方法,基于cglib
        //创建增强器
        Enhancer enhancer = new Enhancer();
        //设置父类目标
        enhancer.setSuperclass(Target.class);
        //设置回调
        enhancer.setCallback(new MethodInterceptor() {
            public Object intercept(Object proxy, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
                //执行前置
                advice.before();
                //执行目标
                Object invoke = method.invoke(target, args);
                //执行后置
                advice.after();
                return invoke;
            }
        });
        //创建代理对象
        Target proxy = (Target) enhancer.create();
        proxy.save();


    }
}
/*
前置增强....
TargetImpl....
后置增强....
 */
相关文章
|
7月前
|
Java 程序员 Maven
Spring AOP入门指南:轻松掌握面向切面编程的基础知识
Spring AOP入门指南:轻松掌握面向切面编程的基础知识
|
7月前
|
XML Java 数据格式
Spring 的AOP 简介,面向切面编程AOP
Spring 的AOP 简介,面向切面编程AOP
89 0
|
7月前
|
XML Java 数据格式
Spring-AOP的基本介绍以及通过先动态代理方式实现
Spring-AOP的基本介绍以及通过先动态代理方式实现
69 0
08Spring - 面向切面编程(AOP)简介
08Spring - 面向切面编程(AOP)简介
171 0
08Spring - 面向切面编程(AOP)简介
|
设计模式 安全 Java
源码分析系列教程(01) - Spring核心总结(AOP篇)
源码分析系列教程(01) - Spring核心总结(AOP篇)
45 0
|
XML Cloud Native Java
Spring AOP使用指南: 强大的面向切面编程技术
Spring AOP使用指南: 强大的面向切面编程技术
108 0
|
监控 Java 测试技术
|
Java Spring
Spring AOP源码学习:基本概念
本文的内容以 AspectJ 来进行介绍。
158 0
Spring AOP源码学习:基本概念
|
安全 Java 开发工具
【AOP 面向切面编程】AOP 简介 ( AspectJ 简介 | AspectJ 下载 )
【AOP 面向切面编程】AOP 简介 ( AspectJ 简介 | AspectJ 下载 )
143 0
【AOP 面向切面编程】AOP 简介 ( AspectJ 简介 | AspectJ 下载 )
|
缓存 安全 Java
Spring 源码学习(八) AOP 使用和实现原理(二)
我们在业务开发中,使用得最多的是面向对象编程(OOP),因为它的代码逻辑直观,从上往下就能查看完整的执行链路。 在这个基础上延伸,出现了面向切面编程(AOP),将可以重复性的横切逻辑抽取到统一的模块中。 例如日志打印、安全监测,如果按照 OOP 的思想,在每个方法的前后都要加上重复的代码,之后要修改的话,更改的地方就会太多,导致不好维护。所以出现了 AOP 编程, AOP 所关注的方向是横向的,不同于 OOP 的纵向。 所以接下来一起来学习 AOP 是如何使用以及 Spring 容器里面的处理逻辑~
Spring 源码学习(八) AOP 使用和实现原理(二)