@EnableAspectJAutoProxy在springboot一定要加嗎

一抑堡、效果演示

以下面的例子演示催跪,

業(yè)務(wù)類,

UserService.java

package com.my.template.service;

import com.my.template.entity.User;
import org.springframework.stereotype.Service;

/**
 * @date 2022/8/9 15:28
 */
@Service
public class UserService implements Us{
    @Override
    public void saveUser(User user){
        System.out.println("保存user對(duì)象到數(shù)據(jù)庫(kù):"+user);
    }
}

切面類夷野,

LogAspect.java

package com.my.template.aop;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

/**
 * @date 2022/8/11 14:12
 */
@Component
@Aspect
public class LogAspect {
    @Pointcut("execution(* com.my.template.service.UserService.*(..))")
    public void pointCut(){

    }
    @Before(value = "pointCut()")
    public void before(JoinPoint joinPoint){
        System.out.println("方法執(zhí)行前-20220816");
    }

    @AfterReturning(value = "pointCut()")
    public void after(JoinPoint joinPoint){
        System.out.println("方法執(zhí)行后-20220816");
    }
}

測(cè)試的controller

UserController.java

package com.my.template.controller;

import com.my.template.entity.User;
import com.my.template.service.Us;
import com.my.template.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @date 2022/8/9 15:35
 */
@RestController
public class UserController {
    @Autowired
    private Us us;
    @RequestMapping("/saveUser")
    public String saveUser(){

        User user=new User();
        user.setId("1");
        user.setName("張三");
        us.saveUser(user);
        return "success";
    }
}

sprinboot的啟動(dòng)類懊蒸,

BootServer.java

package com.my.template;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.context.annotation.ImportResource;

/**
 * 啟動(dòng)類
 * @date 2022/6/3 21:32
 */
@SpringBootApplication()
public class BootServer {
    public static void main(String[] args) {
        try {
            SpringApplication.run(BootServer.class);
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

測(cè)試結(jié)果如下,

2022-08-16 22:30:44.082  INFO 25716 --- [nio-9099-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 6 ms
方法執(zhí)行前-20220816
保存user對(duì)象到數(shù)據(jù)庫(kù):User{name='張三', id='1'}
方法執(zhí)行后-20220816

從上面的測(cè)試結(jié)果來(lái)看悯搔,沒(méi)有加@EnableAspectJAutoProxy注解骑丸,但是AOP生效了,這是為什么妒貌?

二通危、為什么不加@EnableAspectJAutoProxy切面生效

關(guān)于這個(gè)問(wèn)題我排查了很久,最后在依賴中找到了原因灌曙,看下pom文件

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>springTemplate</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    <dependencies>
        <!--spring-boot的web依賴-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.3.RELEASE</version>
        </dependency>
        <!--自定義的starter-->
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>customer-spring-boot-starter</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!--使用springAOP需要引入該依賴-->
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.13</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

在依賴中有spring-boot-starter-web的依賴菊碟,該依賴有下面的依賴,

會(huì)引入spring-boot-autoconfigure的依賴在刺,這是自動(dòng)裝配的依賴逆害,也就是會(huì)讀取其下的spring.factories文件,在該文件中有下面的配置蚣驼,

沒(méi)錯(cuò)就是因?yàn)锳opAutoConfiguration類的問(wèn)題魄幕。下面看具體原因。

三颖杏、原因分析

要看具體原因纯陨,我們就要打開AopAutoConfiguration這個(gè)類看下,

image.png

先看注釋吧,注釋中說(shuō)AopAutoConfiguration等同于@EnableAspectJAutoProxy注解翼抠,也就是該類起的作用和@EnableAspectJAutoProxy是一樣的咙轩,再看該類上的注解,重點(diǎn)看@ConditionalOProperty注解中的內(nèi)容阴颖,意思是如果在配置文件中有”spring.aop.auto“的配置臭墨,如果不配置為true,否則可以配置為false膘盖,現(xiàn)在我的配置文件中是沒(méi)有該配置項(xiàng)的,

server.port=9099
spring.datasource.type=com.mysql.cj.jdbc.MysqlDataSource
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource..driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=yh_dev
spring.datasource..password=DvpJe2x
spring.datasource.url=jdbc:mysql://10.0.0.37:3306/channel_center
#?????
my.customer.name=hello
my.customer.code=autoconfiguration

那么我現(xiàn)在增加該配置尤误,并設(shè)置為false侠畔,

server.port=9099
spring.datasource.type=com.mysql.cj.jdbc.MysqlDataSource
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource..driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=yh_dev
spring.datasource..password=DvpJe2x
spring.datasource.url=jdbc:mysql://10.0.0.37:3306/channel_center
#?????
my.customer.name=hello
my.customer.code=autoconfiguration
spring.aop.auto=false

重啟服務(wù)之后,看測(cè)試結(jié)果损晤,

image.png

從測(cè)試結(jié)果可以看到springAOP沒(méi)有起作用软棺,現(xiàn)在在啟動(dòng)類上加上@EnableAspectJAutoProxy注解,看下測(cè)試結(jié)果尤勋,

image.png

從上面的測(cè)試結(jié)果可以看到喘落,添加了@EnableAspectJAutoProxy注解springAOP生效了。

綜上最冰,在springboot環(huán)境下瘦棋,由于存在spring-boot-autoconfigure依賴,默認(rèn)會(huì)注入AopAutoConfiguration配置類暖哨,該類的作用等同于@EnableAspectJAutoProxy注解赌朋,所以在這種情況下可以不加@EnableAspectJAutoProxy注解,AopAutoConfiguration可以通過(guò)spring.aop.auto屬性控制篇裁;

四沛慢、總結(jié)

本文主要分析了在springboot環(huán)境下,不加@EnableAspectJAutoProxy注解springAOP仍然生效的問(wèn)題达布。為了保險(xiǎn)期間請(qǐng)一律加上@EnableAspetJAutoProxy注解团甲。

  1. AopAutoConfiguration類等同于@EnableAspectJAutoProxy注解;
  2. spring.aop.auto=ture/false屬性可以控制AopAutoConfiguration類是否生效黍聂;

靜態(tài)方法不能使用AOP躺苦;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市产还,隨后出現(xiàn)的幾起案子圾另,更是在濱河造成了極大的恐慌,老刑警劉巖雕沉,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件集乔,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)扰路,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門尤溜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人汗唱,你說(shuō)我怎么就攤上這事宫莱。” “怎么了哩罪?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵授霸,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我际插,道長(zhǎng)碘耳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任框弛,我火速辦了婚禮辛辨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘瑟枫。我一直安慰自己斗搞,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布慷妙。 她就那樣靜靜地躺著僻焚,像睡著了一般。 火紅的嫁衣襯著肌膚如雪膝擂。 梳的紋絲不亂的頭發(fā)上溅呢,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音猿挚,去河邊找鬼咐旧。 笑死,一個(gè)胖子當(dāng)著我的面吹牛绩蜻,可吹牛的內(nèi)容都是我干的铣墨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼办绝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼伊约!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起孕蝉,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤屡律,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后降淮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體超埋,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了霍殴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片媒惕。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖来庭,靈堂內(nèi)的尸體忽然破棺而出妒蔚,到底是詐尸還是另有隱情,我是刑警寧澤月弛,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布肴盏,位于F島的核電站,受9級(jí)特大地震影響帽衙,放射性物質(zhì)發(fā)生泄漏菜皂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一佛寿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧但壮,春花似錦冀泻、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至溯祸,卻和暖如春肢专,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背焦辅。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工博杖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人筷登。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓剃根,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親前方。 傳聞我的和親對(duì)象是個(gè)殘疾皇子狈醉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容