Spring boot 项目(五)——AOP切面

一、AOP简介

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

二、常用场景

1、日志记录
2、权限验证
3、全局异常处理
4、浏览记录

三、 核心概念

1、连接点( Joinpoint)
程序执行过程中的某一行为, 例如, MemberService .get 的调用或者MemberService .delete 抛出异常等行为。=> getUser

2、切入点(Pointcut)
匹配连接点的断言,在 AOP 中通知和一个切入点表达式关联。切面中的所有通知所关注的连接点,都由切入点表达式来决定。

3、通知(Advice)
“切面”对于某个“连接点”所产生的动作。其中,一个“切面”可以包含多个“Advice”。

4、前置通知(Before Advice)
在某连接点(JoinPoint)之前执行的通知,但这个通知不能阻止连接点前的执行。例如,TestAspect 中的 doBefore 方法。

5、后置通知(After Advice)
当某连接点退出的时候执行的通知(不论是正常返回还是异常退出)。
例如,ServiceAspect 中的 returnAfter 方法,所以 Teser 中调用 UserService.delete 抛出异常时,returnAfter 方法仍然执行。

6、返回后通知(After Return Advice)
在某连接点正常完成后执行的通知,不包括抛出异常的情况。

7、环绕通知(Around Advice)
包围一个连接点的通知,类似 Web 中 Servlet 规范中的 Filter 的 doFilter 方法。可 以在方法的调用前后完成自定义的行为, 也可以选择不执行。
例如,ServiceAspect 中的 around 方法。

8、异常通知(After Throwing Advice)
在 方 法 抛 出 异 常 退 出 时 执 行 的 通 知 。

9、目标对象(Target Object)
被一个或者多个切面所通知的对象。例如,AServcieImpl 和 BServiceImpl,当然在实际运行时,Spring AOP 采用代理实现,实际 AOP 操作的是 TargetObject 的代理对象。

10、织入(Weaving)
织入就是将增强添加到对目标类具体连接点上的过程。
织入是一个形象的说法,具体来说,就是生成代理对象并将切面内容融入到业务流程的过程。

11、代理类(Proxy)
一个类被AOP织入增强后,就产生了一个代理类。

12、切面(Aspect)
切面由切点和增强组成,它既包括了横切逻辑的定义,也包括了连接点的定义,SpringAOP就是将切面所定义的横切逻辑织入到切面所制定的连接点中。

四、具体操作

1、引入依赖并刷新

        <!--spring aop 依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

2、新建注解和全局常量(以SelfLog为例)
注解:SelfLog

@Target(ElementType.METHOD)  // 该注解可以作用于那些类型元素上:类、方法、字段
@Retention(RetentionPolicy.RUNTIME) // 运行时生效
public @interface SelfLog {

    /**
     * 操作类型
     * @return
     */
    int type() default GlobalConstant.LOG_TYPE_SELECT;

    /**
     * 模块
     * @return
     */
    String module() default "";

    /**
     * 名称参数
     * @return
     */
    String name() default "name";
}

全局常量:

public class GlobalConstant {


    /**
     * 操作日志类型
     */
    public final static int LOG_TYPE_SELECT = 0;
    public final static int LOG_TYPE_ADD = 1;
    public final static int LOG_TYPE_UPDATE = 2;
    public final static int LOG_TYPE_DEL = 3;
}

3、建立连接(通过SelfLogApsect类连接)

@Aspect
@Component
@Slf4j
public class SelfLogApsect {

    @Autowired
    private HttpServletRequest httpServletRequest;

    /**
     * 切入点
     */
    @Pointcut("@annotation(com.qcby.demo0816.anno.SelfLog)")
    public void  selfLogPonitCut(){

    }
    /**
     * 前置通知
     * @param joinPoint
     */
    @Before("selfLogPonitCut()")
    public void testBefore(JoinPoint joinPoint){
        log.info("我是一个前置通知");
    }


    @After("selfLogPonitCut()")
    public void after(){
        log.info("After................通知");
    }

    @AfterReturning("selfLogPonitCut()")
    public void afterReturning(){
        log.info("AfterReturning................通知");
    }
	//关于异常的通知
    @AfterThrowing("selfLogPonitCut()")
    public void afterThrowing(){
        log.info("AfterThrowing................通知");
    }

    /**
     * 可控制目标函数是否执行
     */
    @Around("selfLogPonitCut()")
    public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
        log.info("Around................通知");
        log.info("进入Around通知....");
        log.info("结束Around通知....");
    }        

4、controller层中想要在哪个方法上用切面就在该方法上加入@SelfLog注解

运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

--流星。

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

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

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

打赏作者

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

抵扣说明:

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

余额充值