亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot中定位切點(diǎn)的兩種常用方法

 更新時(shí)間:2021年06月09日 15:45:04   作者:LukeLong  
有時(shí)候,我們使用AOP來進(jìn)行放的增強(qiáng),編寫切面類的時(shí)候,需要定位在哪個(gè)方法上試用該切面進(jìn)行增強(qiáng),本片文章主要講解兩種在SpringBoot中定位切點(diǎn)的方法,感興趣的可以了解一下

有時(shí)候,我們使用AOP來進(jìn)行放的增強(qiáng),編寫切面類的時(shí)候,需要定位在哪個(gè)方法上試用該切面進(jìn)行增強(qiáng),本片文章主要講解兩種在SpringBoot中定位切點(diǎn)的方法,一種是使用execution表達(dá)式的方法,一種則是利用自定義注解的方法。

接下來以一個(gè)簡(jiǎn)單的例子來講解這兩種方法的使用方式。

<==========方法執(zhí)行前==========>
method();
<==========方法執(zhí)行后==========>

execution 表達(dá)式

execution表達(dá)式的方式主要是在定義切點(diǎn)的時(shí)候,通過表達(dá)式的方式選取到所需要增強(qiáng)的方法。

execution表達(dá)式解讀

execution(<修飾符模式>?<返回類型模式><方法名模式>(<參數(shù)模式>)<異常模式>?)

類型 解讀 是否必須 示例
<修飾符模式> 表示所選的修飾符類型 public/private/...
<返回類型模式> 表示所選的返回值類型 void/int/...
<方法名模式> 表示所選的包或者方法 com.luke.service/com.luke.controller.*/...
(<參數(shù)模式>) 表示所選方法的參數(shù) *(..)/*(String name)/*(int size, ..)/...
<異常模式> 表示所選方法的異常類型 throws Exception/...

 // 匹配指定包中的所有方法
execution(* com.luke.service.*(..))

// 匹配當(dāng)前包中的所有public方法
execution(public * UserService.*(..))

// 匹配指定包中的所有public方法,并且返回值是int類型的方法
execution(public int com.luke.service.*(..))

// 匹配指定包中的所有public方法,并且第一個(gè)參數(shù)是String,返回值是int類型的方法
execution(public int com.luke.service.*(String name, ..))

自定義切面類:

@Aspect
@Component
public class LogAspect {

    @Pointcut("execution(* com.luke.springdata.controller.*.*(..))")
    public void operationLog(){}

    /**
     * 這里只定義一個(gè)Around的增強(qiáng)做展示
     */
    @Around("operationLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) {
        Object proceed = null;
        try {
            System.out.println("方法執(zhí)行前");
            proceed = joinPoint.proceed();
            System.out.println("方法執(zhí)行后");
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }
        return proceed;
    }
}

此切點(diǎn)的execution表達(dá)式為com.luke.springdata.controller包下的所有方法。
使用**@Around**注解表明增強(qiáng)的方法,并且指定切點(diǎn)。

測(cè)試用Controller類

@RestController
@RequestMapping("/person")
public class PersonController {

    @GetMapping("/test")
    public void test(){
        System.out.println("方法執(zhí)行了");
    }
    
}

運(yùn)行項(xiàng)目,調(diào)用該方法,查看結(jié)果。

方法執(zhí)行前
方法執(zhí)行了
方法執(zhí)行后

自定義注解的方法

自定義注解的方式就是在需要增強(qiáng)的方法上面加上自定義的注解即可。

自定義注解類:

@Documented
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Log{
    
}

這里自定義了一個(gè)注解Log,該注解只能加在方法上。
自定義切面類:

@Aspect
@Component
public class LogAspect {

    @Pointcut("@annotation(com.luke.springdata.annotation.Log)")
    public void operationLog(){}

    /**
     * 這里只定義一個(gè)Around的增強(qiáng)做展示
     */
    @Around("operationLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) {
        Object proceed = null;
        try {
            System.out.println("方法執(zhí)行前");
            proceed = joinPoint.proceed();
            System.out.println("方法執(zhí)行后");
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }
        return proceed;
    }
}

這里編寫的自定義個(gè)切面類,用**@Pointcut注解定義一個(gè)切面,并且這次采用@annotation(xxx)**的方式表明如果哪個(gè)方法上添加了xxx注解,則就使用該切面做增強(qiáng)。

同時(shí)在每個(gè)增強(qiáng)的方法上使用該切面,隨后編寫正常的方法增強(qiáng)邏輯即可。

測(cè)試用Controller類

@RestController
@RequestMapping("/person")
public class PersonController {

    @Log
    @GetMapping("/test")
    public void test(){
        System.out.println("方法執(zhí)行了");
    }
    
}

此時(shí)在需要使用切面的方法上加入**@Log**注解,調(diào)用該方法,查看效果。

方法執(zhí)行前
方法執(zhí)行了
方法執(zhí)行后

總結(jié)

兩種方式均能實(shí)現(xiàn)AOP的功能,在使用上,如果某個(gè)包下面的所有方法,都需要這個(gè)切面進(jìn)行增強(qiáng),那么使用execution表達(dá)式的方式更方便。但如果只有部分方法需要,并且分布在不同的類中,則注解的方式更靈活。

到此這篇關(guān)于SpringBoot中定位切點(diǎn)的兩種常用方法的文章就介紹到這了,更多相關(guān)SpringBoot 定位切點(diǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java的Struts框架中棧值和OGNL的使用

    詳解Java的Struts框架中棧值和OGNL的使用

    這篇文章主要介紹了Java的Struts框架中棧值和OGNL的使用,Struts框架是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下
    2015-11-11
  • Netty分布式Server啟動(dòng)流程服務(wù)端初始化源碼分析

    Netty分布式Server啟動(dòng)流程服務(wù)端初始化源碼分析

    本章主要講解server啟動(dòng)的關(guān)鍵步驟,?讀者只需要了解server啟動(dòng)的大概邏輯,?知道關(guān)鍵的步驟在哪個(gè)類執(zhí)行即可,?并不需要了解每一步的運(yùn)作機(jī)制,?之后會(huì)對(duì)每個(gè)模塊進(jìn)行深度分析
    2022-03-03
  • MyBatis入門初體驗(yàn)之使用大全(2)

    MyBatis入門初體驗(yàn)之使用大全(2)

    這篇文章主要介紹了MyBatis入門初體驗(yàn)之使用大全(2)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • 如何理解Java線程池及其使用方法

    如何理解Java線程池及其使用方法

    線程池是首先創(chuàng)建一些線程,它們的集合稱為線程池。使用線程池可以提高性能,它在系統(tǒng)啟動(dòng)時(shí)創(chuàng)建大量空閑的線程,程序?qū)⒁粋€(gè)任務(wù)傳給線程池,它就會(huì)啟動(dòng)一條線程來執(zhí)行這個(gè)任務(wù),執(zhí)行結(jié)束以后,該線程并不會(huì)死亡,而是再次返回線程池中成為空閑狀態(tài),等待執(zhí)行下一個(gè)任務(wù)
    2021-06-06
  • Springboot webscoket自定義定時(shí)器

    Springboot webscoket自定義定時(shí)器

    這篇文章主要介紹了Springboot webscoket自定義定時(shí)器問題,總的來說這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過程。希望通過這道題能給你帶來一種解題優(yōu)化的思路
    2023-01-01
  • Java網(wǎng)絡(luò)編程TCP實(shí)現(xiàn)聊天功能

    Java網(wǎng)絡(luò)編程TCP實(shí)現(xiàn)聊天功能

    這篇文章主要為大家詳細(xì)介紹了Java網(wǎng)絡(luò)編程TCP實(shí)現(xiàn)聊天功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Maven項(xiàng)目更換本地倉(cāng)庫(kù)過程圖解

    Maven項(xiàng)目更換本地倉(cāng)庫(kù)過程圖解

    這篇文章主要介紹了Maven項(xiàng)目更換本地倉(cāng)庫(kù)過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • java學(xué)生信息管理系統(tǒng)源代碼

    java學(xué)生信息管理系統(tǒng)源代碼

    這篇文章主要為大家詳細(xì)介紹了java學(xué)生信息管理系統(tǒng)源代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Java和C的隨機(jī)數(shù)(Random)詳解

    Java和C的隨機(jī)數(shù)(Random)詳解

    本篇文章主要介紹了Java和C隨機(jī)數(shù)(Random),現(xiàn)在分享給大家,也給大家做個(gè)參考,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-09-09
  • Java之如何讀取Excel獲取真實(shí)行數(shù)

    Java之如何讀取Excel獲取真實(shí)行數(shù)

    這篇文章主要介紹了Java之如何讀取Excel獲取真實(shí)行數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。
    2023-06-06

最新評(píng)論