開箱即用,40 個 SpringBoot 常用註解!
大家好,我是Tom哥。
後端開發同學對 Spring Boot 一定不陌生,由於其精巧的架構設計,並提供了豐富的註解,讓我們的開發效率事半功倍。
今天,Tom哥就帶大家一起回顧下 Spring 家族都提供了哪些註解。
一、Spring Web MVC
@RequestMapping
@RequestMapping註解的主要用途是將Web請求與請求處理類中的方法進行對映。Spring MVC和Spring WebFlux都通過 RquestMappingHandlerMapping
和 RequestMappingHndlerAdapter
兩個類來提供對@RequestMapping註解的支援。
@RequestMapping
註解對請求處理類中的請求處理方法進行標註; @RequestMapping
註解擁有以下的六個配置屬性:
-
value
:對映的請求URL或者其別名 -
method
:相容HTTP的方法名 -
params
:根據HTTP引數的存在、預設或值對請求進行過濾 -
header
:根據HTTP Header的存在、預設或值對請求進行過濾 -
consume
:設定在HTTP請求正文中允許使用的媒體型別 -
product
:在HTTP響應體中允許使用的媒體型別
提示:在使用@RequestMapping之前,請求處理類還需要使用@Controller或@RestController進行標記,公眾 號Java精選,回覆java面試,獲取面試資料,支援線上刷題。
下面是使用@RequestMapping的兩個示例:
@RequestMapping還可以對類進行標記,這樣類中的處理方法在對映請求路徑時,會自動將類上@RequestMapping設定的value拼接到方法中對映路徑之前,如下:
@RequestBody
@RequestBody在處理請求方法的引數列表中使用,它可以將請求主體中的引數繫結到一個物件中,請求主體引數是通過 HttpMessageConverter
傳遞的,根據請求主體中的引數名與物件的屬性名進行匹配並繫結值。此外,還可以通過@Valid註解對請求主體中的引數進行校驗。
下面是一個使用 @RequestBody
的示例:
@GetMapping
@GetMapping
註解用於處理HTTP GET請求,並將請求對映到具體的處理方法中。具體來說,@GetMapping是一個組合註解,它相當於是 @RequestMapping(method=RequestMethod.GET)
的快捷方式。
下面是 @GetMapping
的一個使用示例:
@PostMapping
@PostMapping
註解用於處理HTTP POST請求,並將請求對映到具體的處理方法中。@PostMapping與@GetMapping一樣,也是一個組合註解,它相當於是 @RequestMapping(method=HttpMethod.POST)
的快捷方式。
下面是使用 @PostMapping
的一個示例:
@PutMapping
@PutMapping
註解用於處理HTTP PUT請求,並將請求對映到具體的處理方法中,@PutMapping是一個組合註解,相當於是 @RequestMapping(method=HttpMethod.PUT)
的快捷方式。
下面是使用 @PutMapping
的一個示例:
@DeleteMapping
@DeleteMapping
註解用於處理HTTP DELETE請求,並將請求對映到刪除方法中。@DeleteMapping是一個組合註解,它相當於是 @RequestMapping(method=HttpMethod.DELETE)
的快捷方式。
下面是使用 @DeleteMapping
的一個示例:
@PatchMapping
@PatchMapping
註解用於處理HTTP PATCH請求,並將請求對映到對應的處理方法中。@PatchMapping相當於是 @RequestMapping(method=HttpMethod.PATCH)
的快捷方式。
下面是一個簡單的示例:
@ControllerAdvice
@ControllerAdvice
是@Component註解的一個延伸註解,Spring會自動掃描並檢測被@ControllerAdvice所標註的類。 @ControllerAdvice
需要和 @ExceptionHandler
、 @InitBinder
以及 @ModelAttribute
註解搭配使用,主要是用來處理控制器所丟擲的異常資訊。
首先,我們需要定義一個被 @ControllerAdvice
所標註的類,在該類中,定義一個用於處理具體異常的方法,並使用@ExceptionHandler註解進行標記。
此外,在有必要的時候,可以使用 @InitBinder
在類中進行全域性的配置,還可以使用@ModelAttribute配置與檢視相關的引數。使用 @ControllerAdvice
註解,就可以快速的建立統一的,自定義的異常處理類。
下面是一個使用 @ControllerAdvice
的示例程式碼:
@ResponseBody
@ResponseBody
會自動將控制器中方法的返回值寫入到HTTP響應中。特別的, @ResponseBody
註解只能用在被 @Controller
註解標記的類中。如果在被 @RestController
標記的類中,則方法不需要使用 @ResponseBody
註解進行標註。 @RestController
相當於是 @Controller
和 @ResponseBody
的組合註解。
下面是使用該註解的一個示例
@ExceptionHandler
@ExceptionHander
註解用於標註處理特定型別異常類所丟擲異常的方法。當控制器中的方法丟擲異常時,Spring會自動捕獲異常,並將捕獲的異常資訊傳遞給被 @ExceptionHandler
標註的方法。
下面是使用該註解的一個示例:
@ResponseStatus
@ResponseStatus
註解可以標註請求處理方法。使用此註解,可以指定響應所需要的HTTP STATUS。特別地,我們可以使用HttpStauts類對該註解的value屬性進行賦值。
下面是使用 @ResponseStatus
註解的一個示例:
@PathVariable
@PathVariable
註解是將方法中的引數繫結到請求URI中的模板變數上。可以通過 @RequestMapping
註解來指定URI的模板變數,然後使用 @PathVariable
註解將方法中的引數繫結到模板變數上。
特別地, @PathVariable
註解允許我們使用value或name屬性來給引數取一個別名。下面是使用此註解的一個示例:
模板變數名需要使用 { }
進行包裹,如果方法的引數名與URI模板變數名一致,則在 @PathVariable
中就可以省略別名的定義。
下面是一個簡寫的示例:
提示:如果引數是一個非必須的,可選的項,則可以在 @PathVariable
中設定 require = false
@RequestParam
@RequestParam
註解用於將方法的引數與Web請求的傳遞的引數進行繫結。使用 @RequestParam
可以輕鬆的訪問HTTP請求引數的值。
下面是使用該註解的程式碼示例:
該註解的其他屬性配置與 @PathVariable
的配置相同,特別的,如果傳遞的引數為空,還可以通過defaultValue設定一個預設值。示例程式碼如下:
@Controller
@Controller
是 @Component
註解的一個延伸,Spring 會自動掃描並配置被該註解標註的類。此註解用於標註Spring MVC的控制器。下面是使用此註解的示例程式碼:
@RestController
@RestController
是在Spring 4.0開始引入的,這是一個特定的控制器註解。此註解相當於 @Controller
和 @ResponseBody
的快捷方式。當使用此註解時,不需要再在方法上使用 @ResponseBody
註解。
下面是使用此註解的示例程式碼:
@ModelAttribute
通過此註解,可以通過模型索引名稱來訪問已經存在於控制器中的model。下面是使用此註解的一個簡單示例:
與 @PathVariable
和 @RequestParam
註解一樣,如果引數名與模型具有相同的名字,則不必指定索引名稱,簡寫示例如下:
特別地,如果使用 @ModelAttribute
對方法進行標註,Spring會將方法的返回值繫結到具體的Model上。示例如下:
在Spring呼叫具體的處理方法之前,被 @ModelAttribute
註解標註的所有方法都將被執行。
@CrossOrigin
@CrossOrigin
註解將為請求處理類或請求處理方法提供跨域呼叫支援。如果我們將此註解標註類,那麼類中的所有方法都將獲得支援跨域的能力。使用此註解的好處是可以微調跨域行為。使用此註解的示例如下:
@InitBinder
@InitBinder
註解用於標註初始化 WebDataBinider 的方法,該方法用於對Http請求傳遞的表單資料進行處理,如時間格式化、字串處理等。下面是使用此註解的示例:
二、Spring Bean註解
在本小節中,主要列舉與Spring Bean相關的4個註解以及它們的使用方式。
@ComponentScan
@ComponentScan
註解用於配置Spring需要掃描的被元件註解註釋的類所在的包。可以通過配置其basePackages屬性或者value屬性來配置需要掃描的包路徑。屬性是basePackages的別名。
@Component
@Component註解用於標註一個普通的元件類,它沒有明確的業務範圍,只是通知Spring被此註解的類需要被納入到Spring Bean容器中並進行管理。此註解的使用示例如下:
@Service
@Service
註解是 @Component
的一個延伸(特例),它用於標註業務邏輯類。與 @Component
註解一樣,被此註解標註的類,會自動被Spring所管理。下面是使用 @Service
註解的示例:
@Repository
@Repository
註解也是 @Component
註解的延伸,與 @Component
註解一樣,被此註解標註的類會被Spring自動管理起來, @Repository
註解用於標註DAO層的資料持久化類。此註解的用法如下:
三、Spring Dependency Inject與Bean Scops註解
Spring DI註解
@DependsOn
@DependsOn
註解可以配置Spring IoC容器在初始化一個Bean之前,先初始化其他的Bean物件。下面是此註解使用示例程式碼:
@Bean
@Bean註解主要的作用是告知Spring,被此註解所標註的類將需要納入到Bean管理工廠中。@Bean註解的用法很簡單,在這裡,著重介紹@Bean註解中 initMethod
和 destroyMethod
的用法。示例如下:
Scops註解
@Scope
@Scope註解可以用來定義 @Component 標註的類的作用範圍以及@Bean所標記的類的作用範圍。@Scope所限定的作用範圍有: singleton
、 prototype
、 request
、 session
、 globalSession
或者其他的自定義範圍。這裡以prototype為例子進行講解。
當一個Spring Bean被宣告為prototype(原型模式)時,在每次需要使用到該類的時候,Spring IoC容器都會初始化一個新的改類的例項。在定義一個Bean時,可以設定Bean的scope屬性為 prototype:scope=“prototype”
,也可以使用@Scope註解設定,如下:
@Scope(value=ConfigurableBeanFactory.SCOPE_PROPTOTYPE)
下面將給出兩種不同的方式來使用@Scope註解,示例程式碼如下:
@Scope 單例模式
當@Scope的作用範圍設定成Singleton時,被此註解所標註的類只會被Spring IoC容器初始化一次。 在預設情況下,Spring IoC容器所初始化的類例項都為singleton。 同樣的原理,此情形也有兩種配置方式,示例程式碼如下:
四、容器配置註解
@Autowired
@Autowired註解用於標記Spring將要解析和注入的依賴項。此註解可以作用在建構函式、欄位和setter方法上。
作用於建構函式
下面是@Autowired註解標註建構函式的使用示例:
作用於setter方法
下面是@Autowired註解標註setter方法的示例程式碼:
作用於欄位
@Autowired註解標註欄位是最簡單的,只需要在對應的欄位上加入此註解即可,示例程式碼如下:
@Primary
當系統中需要配置多個具有相同型別的bean時,@Primary可以定義這些Bean的優先順序。下面將給出一個例項程式碼來說明這一特性:
輸出結果:
this is send DingDing method message.
@PostConstruct與@PreDestroy
值得注意的是,這兩個註解不屬於Spring,它們是源於JSR-250中的兩個註解,位於 common-annotations.jar
中。@PostConstruct 註解用於標註在Bean被Spring初始化之前需要執行的方法。@PreDestroy 註解用於標註Bean被銷燬前需要執行的方法。下面是具體的示例程式碼:
@Qualifier
當系統中存在同一型別的多個Bean時,@Autowired在進行依賴注入的時候就不知道該選擇哪一個實現類進行注入。此時,我們可以使用@Qualifier註解來微調,幫助@Autowired選擇正確的依賴項。下面是一個關於此註解的程式碼示例:
五、Spring Boot註解
@SpringBootApplication
@SpringBootApplication
註解是一個快捷的配置註解,在被它標註的類中,可以定義一個或多個Bean,並自動觸發自動配置Bean和自動掃描元件。此註解相當於 @Configuration
、 @EnableAutoConfiguration
和 @ComponentScan
的組合。
在Spring Boot應用程式的主類中,就使用了此註解。示例程式碼如下:
@SpringBootApplication public class Application{ public static void main(String [] args){ SpringApplication.run(Application.class,args); } }
@EnableAutoConfiguration
@EnableAutoConfiguration註解用於通知Spring,根據當前類路徑下引入的依賴包,自動配置與這些依賴包相關的配置項。
@ConditionalOnClass與@ConditionalOnMissingClass
這兩個註解屬於類條件註解,它們根據是否存在某個類作為判斷依據來決定是否要執行某些配置。下面是一個簡單的示例程式碼:
@Configuration @ConditionalOnClass(DataSource.class) class MySQLAutoConfiguration { //... }
@ConditionalOnBean與@ConditionalOnMissingBean
這兩個註解屬於物件條件註解,根據是否存在某個物件作為依據來決定是否要執行某些配置方法。示例程式碼如下:
@Bean @ConditionalOnBean(name="dataSource") LocalContainerEntityManagerFactoryBean entityManagerFactory(){ //... } @Bean @ConditionalOnMissingBean public MyBean myBean(){ //... }
@ConditionalOnProperty
@ConditionalOnProperty 註解會根據Spring配置檔案中的配置項是否滿足配置要求,從而決定是否要執行被其標註的方法。示例程式碼如下:
@Bean @ConditionalOnProperty(name="alipay",havingValue="on") Alipay alipay(){ return new Alipay(); }
@ConditionalOnResource
此註解用於檢測當某個配置檔案存在使,則觸發被其標註的方法,下面是使用此註解的程式碼示例:
@ConditionalOnResource(resources = "classpath:website.properties") Properties addWebsiteProperties(){ //... }
@ConditionalOnWebApplication與@ConditionalOnNotWebApplication
這兩個註解用於判斷當前的應用程式是否是Web應用程式。如果當前應用是Web應用程式,則使用Spring WebApplicationContext,並定義其會話的生命週期。下面是一個簡單的示例:
@ConditionalOnWebApplication HealthCheckController healthCheckController(){ //... }
@ConditionalExpression
此註解可以讓我們控制更細粒度的基於表示式的配置條件限制。當表示式滿足某個條件或者表示式為真的時候,將會執行被此註解標註的方法。
@Bean @ConditionalException("${localstore} && ${local == 'true'}") LocalFileStore store(){ //... }
@Conditional
@Conditional 註解可以控制更為複雜的配置條件。在Spring內建的條件控制註解不滿足應用需求的時候,可以使用此註解定義自定義的控制條件,以達到自定義的要求。下面是使用該註解的簡單示例:
@Conditioanl(CustomConditioanl.class) CustomProperties addCustomProperties(){ //... }
總結
本次課程總結了Spring Boot中常見的各型別註解的使用方式,讓大家能夠統一的對Spring Boot常用註解有一個全面的瞭解。
由於篇幅的原因,關於Spring Boot不常用的一些註解,將在下一次分享中進行補充和說明。
來源:www.ramostear.com
關於我:Tom哥,前阿里P7技術專家,offer收割機,參加多次淘寶雙11大促活動。歡迎關注,我會持續輸出更多經典原創文章,為你晉級大廠助力
微信8.0將好友放開到了一萬,小夥伴可以加我大號了,先到先得,再滿就真沒了。 掃描下方二維碼即可加我微信啦, 2022,抱團取暖,一起牛逼。
推薦閱讀:
- 位元組一面:Redis主節點宕機,如何處理?
- 5個基礎內功,程式設計師要從這入手!
- 一文搞懂 Sentinel 限流熔斷!
- 阿里一面:聊聊Java中執行緒的生命週期狀態
- Elasticsearch 億級資料效能優化!
- 你真的會面試嗎?
- 硬核的網路學習資料!再也不用擔心被面試官摩擦
- 秒殺系統架構!
- 開箱即用,40 個 SpringBoot 常用註解!
- 繁忙的工作之外,大佬都在幹這件事....
- 9大外掛,高效寫程式碼,老闆要給加薪
- 阿里一面: Spring 有哪些擴充套件點?
- SpringBoot 整合 Elasticsearch 實現海量級資料搜尋
- 一文詳解 JDK1.8 的 Lambda、Stream、LocalDateTime
- 新來的技術總監,指導大家落地DDD,那是一個服氣!
- 併發程式設計的三大核心問題
- 聽說你精通 MyBatis!我們切磋下
- 滿屏的 if-else,要怎麼優化?
- Api 介面優化的幾個技巧
- MyBatis-plus 創業公司首選利器!