aop java面试_JAVA面试题系列:你必须要懂的Spring-Aop

本文详细介绍了Spring AOP的概念及其在实际研发中的应用,包括为何需要AOP来解决面向对象编程中的横切代码问题,以及AOP中的关键概念:切点(PointCut)、通知(Advice)和连接点(JoinPoint)。通过一个具体的权限校验的例子,展示了如何定义切点、通知,并如何在连接点获取方法参数,从而实现代码的解耦和复用。
摘要由CSDN通过智能技术生成

原标题:JAVA面试题系列:你必须要懂的Spring-Aop

在实际研发中,Spring是我们经常会使用的框架,毕竟它们太火了,也因此Spring相关的知识点也是面试必问点,今天我们就大话Aop。

特地在周末推文,因为该篇文章阅读起来还是比较轻松诙谐的,当然了,更主要的是周末的我也在充电学习,希望有追求的朋友们也尽量不要放过周末时间,适当充电,为了走上人生巅峰,迎娶白富美。

接下来,直接进入正文。

为什么要有aop

我们都知道Java是一种面向对象编程【也就是OOP】的语言,不得不说面向对象编程是一种及其优秀的设计,但是任何语言都无法十全十美,对于OOP语言来说,当需要为部分对象引入公共部分的时候,OOP就会引入大量的重复代码【这些代码我们可以称之为横切代码】。而这也是Aop出现的原因,没错,Aop就是被设计出来弥补OOP短板的。Aop便是将这些横切代码封装到一个可重用模块中,继而降低模块间的耦合度,这样也有利于后面维护。

Aop是什么东西

学过Spring的都知道,Spring内比较核心的功能便是Ioc和Aop,Ioc的主要作用是应用对象之间的解耦,而Aop则可以实现横切代码【如权限、日志等】与他们绑定的对象之间的解耦,举个浅显易懂的小栗子,在用户调用很多接口的地方,我们都需要做权限认证,判断用户是否有调用该接口的权限,如果每个接口都要自己去做类似的处理,未免有点sb了,也不够装x,因此Aop就可以派上用场了,将这些处理的代码放到切片中,定义一下切片、连接点和通知,刷刷刷跑起来就ojbk了。

想要了解Aop,就要先理解以下几个术语,如PointCut、Advice、JoinPoint。接下来尽量用白话文描述下。

PointCut【切点】

其实切点的概念很好理解,你想要去切某个东西之前总得先知道要在哪里切入是吧,切点格式如下:execution(* com.nuofankj.springdemo.aop.Service.(…))

可以看出来,格式使用了正常表达式来定义那个范围内的类、那些接口会被当成切点,简单明了。

Advice

Advice行内很多人都定义成了通知,但是我总觉得有点勉强。所谓的Advice其实就是定义了Aop何时被调用,确实有种通知的感觉,何时调用其实也不过以下几种:

Before 在方法被调用之前调用

After 在方法完成之后调用

After-returning 在方法成功执行之后调用

After-throwing 在方法抛出异常之后调用

Around 在被通知的方法调用之前和调用之后调用

JoinPoint【连接点】

JoinPoint连接点,其实很好理解,上面又有通知、又有切点,那和具体业务的连接点又是什么呢?没错,其实就是对应业务的方法对象,因为我们在横切代码中是有可能需要用到具体方法中的具体数据的,而连接点便可以做到这一点。

给出一个Aop在实际中的应用场景

先给出两个业务内的接口,一个是聊天,一个是购买东西

ca0157c42e8c22bdf041fb966e8cd10e.png

ee38040f28cf719675499558e127e552.png

接下来该给出说了那么久的切片了

f104c3d6921b7f466c14f6f43bbbfb1e.png

可以从中看到PointCut【切点】是

execution(* com.nuofankj.springdemo.aop.Service.(…))

Advice是

Before

JoinPoint【连接点】是

MethodSignature signature = (MethodSignature) joinPoint.getSignature();

Method method = signature.getMethod();

代码浅显易懂,其实就是将ChatService和BuyService里边给userId做权限校验的逻辑抽出来做成切片。

那么如何拿到具体业务方法内的具体参数呢?

这里是定义了一个新的注解

2232defb91934f31fd7197a20a00a987.png

作用可以直接看注释,使用地方如下

120066498c9d7e381b8f3f3b8f1c7458.png

可以看到对应接口使用了AuthPermission的注解,而取出的地方在于

55f8d7212d789a7f56442c6204e7c131.png

是的,这样便可以取出来对应的接口传递的userId具体是什么了,而校验逻辑可以自己处理。

送佛送到西,不对,撸码撸整套,接下来给出运行的主类

c31cfebdfb2129712de0813b6d482c29.png

可以看到,上面有一个接口传递的userId是1,另一个是123,而上面权限认证只有1才说通过,否则会抛出异常。

运行结果如下

537015714f95f3bf94cca9244c38d44e.png

运行结果可想而知,1的通过验证,123的失败。返回搜狐,查看更多

责任编辑:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值