日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SpringBoot2.1.x,創建自己的spring-boot-starter自動配置模塊操作

瀏覽:143日期:2023-04-24 16:53:31

一)spring-boot-starter命名規則

自動配置模塊命名規則:xxx-spring-boot,如:aspectlog-spring-boot

啟動器命名規則:xxx-spring-boot-starter,如:aspectlog-spring-boot-starter

如兩者只有一個模塊:建議以xxx-spring-boot-starter方式命名。

springboot建議以xxx前綴的方式對自己的自動配置命名的。

二)spring-boot-starter條件注解

注解 說明 @ConditionalOnClass 指定加載的類 @ConditionalOnMissingClass 指定不加載的類 @ConditionalOnBean 指定需要加載的bean @ConditionalOnMissingBean 指定不需要加載的bean @ConditionalOnProperty 指定加載配置文件中的屬性,如yml或properties文件 @ConditionalOnResource 檢查特定的資源是否存在,如:file:/home/user/test.dat @ConditionalOnExpression 使用SpEL表達式

該文章使用@ConditionalOnProperty注解實現。

三)創建自己的aspectlog-spring-boot-starter日志打印自動配置模塊

第一步:創建一個aspectlog-spring-boot-starter名稱的maven項目

在pom.xml文件中引入springboot相應jar

<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>com.oysept</groupId> <artifactId>aspectlog-spring-boot-starter</artifactId> <version>0.0.1-SNAPSHOT</version> <!-- springboot版本信息 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.4.RELEASE</version> </parent> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-autoconfigure</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> <!-- 自定義配置 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> </dependencies></project>

spring-boot-configuration-processor作用:會在源數據文件(META-INF/spring-autoconfigure-metadata.properties)中自動掃描加載和自動配置有關的條件。也就是說,當編寫starter時,會讀取自動配置的條件,寫入源數據文件中。

第二步:定義一個AspectLog注解類

該注解作用于方法上,并在運行時啟用

package com.oysept.autoconfiguration.aspectlog; import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target; @Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public @interface AspectLog {}

第三步:創建一個AspectLogProperties類,用于加載yml或properties中的屬性

package com.oysept.autoconfiguration.aspectlog; import org.springframework.boot.context.properties.ConfigurationProperties; @ConfigurationProperties('aspectlog')public class AspectLogProperties { private boolean enable; public boolean isEnable() { return enable; } public void setEnable(boolean enable) { this.enable = enable; }}

第四步:創建一個AspectLogAutoConfiguration打印日志自動配置類

package com.oysept.autoconfiguration.aspectlog; import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.EnableAspectJAutoProxy;import org.springframework.core.PriorityOrdered; @Aspect@EnableAspectJAutoProxy(exposeProxy = true, proxyTargetClass = true)@Configuration@ConditionalOnProperty(prefix='aspectlog', name = 'enable', havingValue = 'true', matchIfMissing = true)public class AspectLogAutoConfiguration implements PriorityOrdered { protected Logger logger = LoggerFactory.getLogger(getClass()); @Around('@annotation(com.oysept.autoconfiguration.aspectlog.AspectLog) ') public Object isOpen(ProceedingJoinPoint thisJoinPoint) throws Throwable { //執行方法名稱 String taskName = thisJoinPoint.getSignature() .toString().substring( thisJoinPoint.getSignature() .toString().indexOf(' '), thisJoinPoint.getSignature().toString().indexOf('(')); taskName = taskName.trim(); long time = System.currentTimeMillis(); Object result = thisJoinPoint.proceed(); logger.info('==>aspectlog method:{} run :{} ms', taskName, (System.currentTimeMillis() - time)); return result; } @Override public int getOrder() { //保證事務等切面先執行 return Integer.MAX_VALUE; }}

注解說明:

@ConditionalOnProperty(prefix = 'aspectLog', name = 'enable',havingValue = 'true', matchIfMissing = true)

當yml或properties配置文件中有aspectLog.enable=true時開啟,如果配置文件沒有設置aspectLog.enable也開啟。

第五步:創建spring.factories文件,該文件是springboot規定的配置文件,把自動配置類按規則配置

先在src/main/resources下創建一個META-INF文件夾,然后在文件夾下創建spring.factories

org.springframework.boot.autoconfigure.EnableAutoConfiguration=

com.oysept.autoconfiguration.aspectlog.AspectLogAutoConfiguration

META-INF/spring.factories是spring的工廠機制,在這個文件中定義的類,都會被自動加載。多個配置使用逗號分割,換行用

第六步:使用mvn install方式把該模塊自動打包

SpringBoot2.1.x,創建自己的spring-boot-starter自動配置模塊操作

四)測試aspectlog-spring-boot-starter打印日志配置

另外創建一個springboot_starter_test名稱的maven項目

在pom中引入aspectlog-spring-boot-starter的jar

<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>com.oysept</groupId> <artifactId>springboot_starter_test</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.4.RELEASE</version> <relativePath/> </parent> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 引入自定義aspectlog-spring-boot-starter 打印日志jar --> <dependency> <groupId>com.oysept</groupId> <artifactId>aspectlog-spring-boot-starter</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency> </dependencies> <!-- maven打包插件,在cmd命令窗口執行,如: mvn install -U --> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build></project>

創建一個application.yml,配置啟動的端口,默認是8080

server:

port: 8080

創建application啟動類

package com.oysept; import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplicationpublic class TestSpringBootStarterApplication { public static void main(String[] args) { SpringApplication.run(TestSpringBootStarterApplication.class, args); }}

創建測試AspectLog功能controller

package com.oysept.controller; import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.RestController; import com.oysept.autoconfiguration.aspectlog.AspectLog; @RestControllerpublic class GetController { /** * 訪問地址: http://localhost:8080/test/starter/aspectlog?param=TTTEEESSSTTT * @return */ @AspectLog @RequestMapping(value='/test/starter/aspectlog', method = RequestMethod.GET) public String testStarterAspectLog(@RequestParam(value = 'param') String param) { System.out.println('==>/test/starter/aspectlog, param: ' + param); // 處理業務邏輯 return '/test/starter/aspectlog SUCCESS!'; }}

在想要打印日志的方法上,使用@AspectLog注解

啟動TestSpringBootStarterApplication中的main方法

在瀏覽器中輸入:http://localhost:8080/test/starter/aspectlog?param=TTTEEESSSTTT

然后在控制臺查看效果:

SpringBoot2.1.x,創建自己的spring-boot-starter自動配置模塊操作

以上這篇SpringBoot2.1.x,創建自己的spring-boot-starter自動配置模塊操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文字幕av一区二区三区人| 国产精品av久久久久久麻豆网| 中文字幕在线官网| 国产精品一区亚洲| 久久国产高清| 久久午夜影视| 美国欧美日韩国产在线播放| 黄色日韩精品| 亚洲黄色在线| 99国产精品久久久久久久成人热| se01亚洲视频| 日韩av一区二区三区四区| 亚洲精选av| 日本综合精品一区| 欧美伊人影院| 国产精品亲子伦av一区二区三区| 国产三级精品三级在线观看国产| 亚洲午夜久久| 少妇精品在线| 日韩在线播放一区二区| 99精品99| 老色鬼久久亚洲一区二区| 一区二区精彩视频| 日韩毛片一区| 国产极品久久久久久久久波多结野 | 日本午夜免费一区二区| 日韩不卡手机在线v区| 欧美黄色精品| 亚洲精品福利电影| 午夜久久影院| 中文字幕免费一区二区| 国产情侣一区在线| 国产日韩免费| 成人综合一区| av亚洲在线观看| 中文字幕乱码亚洲无线精品一区| 日韩高清一区在线| 麻豆国产精品777777在线| 午夜久久中文| 国产精品呻吟| 国产亚洲电影| 神马午夜在线视频| 蜜桃av一区| 国产乱码精品一区二区亚洲| 国产一区二区三区亚洲综合| 激情欧美国产欧美| 日韩精品导航| 久久精品国产网站| 视频福利一区| 日本不卡的三区四区五区| 视频在线不卡免费观看| 狠狠爱www人成狠狠爱综合网| 婷婷精品久久久久久久久久不卡| 久久精品国内一区二区三区| 亚洲精品国产嫩草在线观看 | 久久香蕉精品香蕉| 午夜国产精品视频| 久久成人精品| 国产精品99久久免费| 日韩欧美不卡| 综合欧美精品| 久久午夜影院| 亚洲欧美日韩专区| 欧美黄页在线免费观看| 亚洲黑丝一区二区| 欧美日韩网址| 99热精品久久| 日韩精品福利一区二区三区| 色婷婷亚洲mv天堂mv在影片| 石原莉奈在线亚洲三区| 福利一区二区三区视频在线观看| 亚州av乱码久久精品蜜桃| 亚洲一级大片| 日韩在线看片| 日本色综合中文字幕| 久久视频精品| 欧美激情视频一区二区三区免费| 亚洲国产专区校园欧美| 国产精品久久久免费| 91久久黄色| 国产成人久久精品一区二区三区| 喷白浆一区二区| 日韩在线观看不卡| 国产精品欧美日韩一区| 欧美一区三区| 精品91久久久久| 欧美成人一二区| 免费欧美一区| 精品视频91| 日本成人精品| 日韩午夜黄色| 在线中文字幕播放| 日韩avvvv在线播放| 五月婷婷亚洲| 国产精品99视频| 日韩av中文在线观看| 黑丝一区二区三区| av最新在线| 国产乱码精品| 亚洲精品影视| 最新国产拍偷乱拍精品| 超级白嫩亚洲国产第一| 日韩激情一区二区| 丝瓜av网站精品一区二区| 欧美不卡高清一区二区三区| 欧美激情一区| 欧美日韩一区二区三区不卡视频| 日韩视频中文| 欧美va天堂| 精品丝袜在线| 亚洲天堂av影院| 久久久精品国产**网站| 日本综合视频| 亚洲一二av| 亚洲一区av| 玖玖精品视频| 免费看的黄色欧美网站| 成人日韩精品| 日韩一区二区三区在线免费观看| 高潮久久久久久久久久久久久久| 国产精品调教| 国产精品对白| 国产精品久久久久9999高清| 青青草精品视频| 中文字幕免费精品| 中文字幕日韩亚洲| 蜜臀精品久久久久久蜜臀| 国产真实久久| 久久久久久久久丰满| 国产欧美三级| www在线观看黄色| 国产精品传媒麻豆hd| 国产精品美女| 亚洲深夜av| 久久亚洲一区| 蜜臀国产一区二区三区在线播放| 国产一区亚洲| 欧美在线资源| 国产午夜精品一区二区三区欧美 | 激情综合网址| 国产综合亚洲精品一区二| 久久蜜桃av| 一区在线视频观看| 国产日韩欧美在线播放不卡| 免费观看久久久4p| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久久一本精品| 欧美日本精品| 久久人人97超碰国产公开结果| 色老板在线视频一区二区| 国产精品一区二区99| 国产日韩欧美在线播放不卡| 久久亚洲国产精品尤物| 欧美13videosex性极品| 激情综合网址| 蜜臀av性久久久久蜜臀aⅴ流畅 | 麻豆视频久久| 日本成人在线不卡视频| 免费看日韩精品| 久久精品国产大片免费观看| 亚洲香蕉网站| 91久久在线| 国产aa精品| 电影天堂国产精品| 三级在线看中文字幕完整版| 丝袜美腿诱惑一区二区三区| 日本中文字幕不卡| 日韩高清不卡一区二区| 免费观看日韩电影| 国产精品亚洲综合久久| 日韩精品一二三四| 日本精品影院| 久久国产主播| 日韩天堂av| 亚洲麻豆一区| 精品欠久久久中文字幕加勒比| 日本在线啊啊| 免费久久精品| 一区二区精彩视频| 国产精品主播在线观看| 日韩1区2区| 激情视频网站在线播放色| 久久精品国内一区二区三区水蜜桃| 国产在线观看www| 欧美成a人免费观看久久| 免费久久精品| 亚洲另类av| 日韩国产91| 国产精品黑丝在线播放| 国产精品不卡| 亚洲久久视频| 精品三级av| 一级欧洲+日本+国产| 亚洲开心激情| 91tv亚洲精品香蕉国产一区| 亚洲欧美日韩精品一区二区| 日韩av网站在线免费观看| 久久精品三级| 亚洲精品97| 欧美日韩1区2区3区|