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

spring項(xiàng)目中切面及AOP的使用方法

 更新時(shí)間:2021年06月26日 15:09:31   作者:努力''搬磚''學(xué)習(xí)的嚴(yán)惜  
我們知道,spring兩大核心,IOC(控制反轉(zhuǎn))和AOP(切面),那為什么要使用AOP,AOP是什么呢?帶著這些問(wèn)題通過(guò)本文學(xué)習(xí)下吧

使用AOP的原因(AOP簡(jiǎn)介)

我們知道,spring兩大核心,IOC(控制反轉(zhuǎn))和AOP(切面),那為什么要使用AOP,AOP是什么呢,嚴(yán)格來(lái)說(shuō),AOP是一種編程規(guī)范,是一種編程思想,并非spring創(chuàng)造,AOP可以幫助我們?cè)谝欢ǔ潭壬蠌娜哂嗟耐ㄓ玫臉I(yè)務(wù)邏輯中解脫出來(lái),最明顯的,比如每個(gè)接口的請(qǐng)求,都要記錄日志,那這個(gè)操作如果每個(gè)地方都寫,就會(huì)很繁瑣,當(dāng)然,記錄日志并不是唯一的用法

spring的AOP只能基于IOC來(lái)管理,它只能作用于spring容器的bean

并且,spring的AOP為的是解決企業(yè)開(kāi)發(fā)中出現(xiàn)最普遍的方法織入,并不是為了像AspectJ那樣,成為一個(gè)完全的AOP使用解決方案

AOP的使用

開(kāi)啟AOP支持

要使用AOP,首先要開(kāi)啟AOP的支持

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

啟動(dòng)類添加 @EnableAspectJAutoProxy 注解

編寫切面類與測(cè)試方法

@Aspect
@Component
public class MyAop {
 
}
@RestController
public class OneController {
 
    @GetMapping("/doCheck")
    public String doCheck (int age) {
        System.out.println("doCheck");
        if (age > 1) {
        throw new MyException(ExceptionEnu.SUCCESS);
        } else {
            throw new MyException(ExceptionEnu.FAILD);
        }
    }
 
}

記得切面類交給spring管理哦~ @Component

編寫切面方法

@Before

這個(gè)注解的用法呢,就是說(shuō),在執(zhí)行你要執(zhí)行的東西之前,執(zhí)行加了這個(gè)注解的方法

比如

 @Before(value = "execution (* own.study.web.OneController.*(..))")
    public void doAop( ) {
        System.out.println("before aop");
    }

也就是說(shuō),如果我要調(diào)用 OneController 的方法,在調(diào)用到之前,會(huì)執(zhí)行這個(gè) doAop 方法

讓我們來(lái)測(cè)試一下

@After

這個(gè)注解的用法,就是說(shuō),當(dāng)你執(zhí)行完你的方法之后,真的返回給調(diào)用方之前,執(zhí)行加了這個(gè)注解的方法

比如

@After(value = "execution (* own.study.web.OneController.*(..))")
    public void doAfter() {
        System.out.println("after aop");
    }

讓我們來(lái)測(cè)試一下

@AfterThrowing

見(jiàn)名知意,在發(fā)生異常后,執(zhí)行加了此注解的方法

注意我上面寫的測(cè)試方法了嗎?我拋出了自定義的異常

讓我們測(cè)試一下

@AfterReturning

這個(gè)注解的用法也是看名字就能猜到,執(zhí)行完后,執(zhí)行此方法

但是!這個(gè)執(zhí)行完,指的是正常執(zhí)行完,不拋出異常的那種,不信?我們來(lái)試試

@Around

這個(gè)是最為強(qiáng)大的一個(gè)注解,環(huán)繞通知,方法執(zhí)行前和執(zhí)行后都會(huì)執(zhí)行加了這個(gè)注解的方法

@Around(value = "execution (* own.study.web.OneController.*(..))")
    public Object doAround (ProceedingJoinPoint point) throws Throwable {
        Gson gson = new Gson();
        System.out.println("進(jìn)入AOP --->" + System.currentTimeMillis());
        System.out.println("方法名 = " + point.getSignature().toShortString());
 
        Object result = point.proceed();
 
        System.out.println("響應(yīng)參數(shù)為 = " + gson.toJson(result));
        System.out.println("AOP完事了 --->" + System.currentTimeMillis());
        return result;
    }
@RestController
public class OneController {
 
    @GetMapping("/doCheck")
    public Object doCheck (int age) throws InterruptedException {
        System.out.println("這個(gè)是controller的方法 --->" + System.currentTimeMillis());
        Thread.sleep(2000l);
        System.out.println("doCheck");
 
       return new MyRsp("1", "success");
    }
 
}

但是,注意!這個(gè)環(huán)繞通知不是萬(wàn)能的,不是一定好,大家按需要使用,比如一個(gè)場(chǎng)景,當(dāng)你的方法拋出了異常,這個(gè)環(huán)繞通知就不會(huì)再繼續(xù)執(zhí)行

我們來(lái)實(shí)驗(yàn)一下

改寫controller的方法

@RestController
public class OneController {
 
    @GetMapping("/doCheck")
    public Object doCheck (int age) throws InterruptedException {
        System.out.println("這個(gè)是controller的方法 --->" + System.currentTimeMillis());
        Thread.sleep(2000l);
        System.out.println("doCheck");
        throw new MyException("1", "success");
 
//       return new MyRsp("1", "success");
    }
 
}

看,AOP后續(xù)的沒(méi)有被執(zhí)行

以上就是spring的切面,AOP的使用的詳細(xì)內(nèi)容,更多關(guān)于spring的切面,AOP的使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • jstack報(bào)錯(cuò)Unable to open socket file解決

    jstack報(bào)錯(cuò)Unable to open socket file解決

    這篇文章主要為大家介紹了jstack報(bào)錯(cuò)Unable to open socket file的解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-02-02
  • Java使用DateFormatter格式化日期時(shí)間的方法示例

    Java使用DateFormatter格式化日期時(shí)間的方法示例

    這篇文章主要介紹了Java使用DateFormatter格式化日期時(shí)間的方法,結(jié)合具體實(shí)例分析了java使用DateFormatter格式化日期時(shí)間的相關(guān)操作技巧,需要的朋友可以參考下
    2017-04-04
  • SpringBoot整合Swagger Api自動(dòng)生成文檔的實(shí)現(xiàn)

    SpringBoot整合Swagger Api自動(dòng)生成文檔的實(shí)現(xiàn)

    本文主要介紹了SpringBoot整合Swagger Api自動(dòng)生成文檔的實(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Rxjava+Retrofit+MVP實(shí)現(xiàn)購(gòu)物車功能

    Rxjava+Retrofit+MVP實(shí)現(xiàn)購(gòu)物車功能

    這篇文章主要為大家詳細(xì)介紹了Rxjava+Retrofit+MVP實(shí)現(xiàn)購(gòu)物車功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Java利用EasyExcel讀取寫入Excel詳情

    Java利用EasyExcel讀取寫入Excel詳情

    這篇文章主要介紹了Java利用EasyExcel讀取寫入Excel詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • 基于TCP通信丟包原因總結(jié)(推薦)

    基于TCP通信丟包原因總結(jié)(推薦)

    下面小編就為大家?guī)?lái)一篇基于TCP通信丟包原因總結(jié)(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 詳解JAVA8 函數(shù)式接口

    詳解JAVA8 函數(shù)式接口

    這篇文章主要介紹了JAVA8 函數(shù)式接口的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • springmvc限流攔截器的示例代碼

    springmvc限流攔截器的示例代碼

    本篇文章主要介紹了springmvc限流攔截器的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Struts中使用validate()輸入校驗(yàn)方法詳解

    Struts中使用validate()輸入校驗(yàn)方法詳解

    這篇文章主要介紹了Struts中使用validate()輸入校驗(yàn)方法,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-09-09
  • Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置的教程

    Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置的教程

    這篇文章主要介紹了Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09

最新評(píng)論