Spring?Boot?Rest常用框架注解詳情簡介
前言:
讓我們了解一下Spring Boot Rest框架注釋。它是如此簡單和快速。在本文中,我將嘗試解釋Spring Boot Rest API的不同注釋。這些注釋是Spring Boot中REST API所必需的。
開始Spring Boot Rest的先決條件
最需要了解的是Spring容器或IOC。除此之外,還必須具備Java注釋的基本知識。因為Spring Boot應用程序充滿了注釋。最后但并非最不重要的一點是,應該澄清REST的概念,至少是基本概念。例如GET、POST、PUT、DELETE和Request body和response、headers等。
在Spring Initializer創(chuàng)建Spring Boot項目
Spring Boot最棒的一點是它有一個web應用程序用于入門。只需點擊幾個表單字段和按鈕,就可以準備好初學者文件。這包括pom。包含所有必需依賴項的xml。只需轉(zhuǎn)到Spring Initializer:https://start.spring.io/。如下面的屏幕截圖所示,填寫適當?shù)臄?shù)據(jù)。然后單擊右上角的添加依賴項按鈕。鍵入并選擇Web。我還將為log和Pojo添加Lombok。

完成后,只需單擊generate按鈕,就會下載一個包含這些文件的zip文件(pom.xml)。將其解壓縮并在IDE中打開。我將使用IntelliJ IDEA。這個IDE幫助我利用各種功能提高工作效率。
Spring Boot注解
整個Spring Boot都依賴于注釋。對于不同的需求和過程,有各種注釋。其余部分有4-5個主要注釋。讓我們一個接一個地看它們,并將它們應用到我們的示例中。
@RestController
類上使用了@RestController注釋。它將類定義為Rest的控制器。這是一個RESTful版本的控制器,添加了ResponseBy的組合。這樣,您的響應就會自動轉(zhuǎn)換為JSON、XML或任何已定義的響應類型,而無需單獨使用ResponseBy注釋。
@RestController
public class ArticleRestController {}其余的注釋在@RestController類下使用。
@RequestMapping
用于將特定端點映射到函數(shù)或方法。這有助于定義端點的路徑、方法、響應類型、請求類型等。
@RequestMapping(value = "/articles", method = RequestMethod.GET, produces = "application/json")
public List<Article> getArticles() { }在上面的示例中,值表示它映射到的路徑。例如,localhost:8080/articles。方法類型是GET,它生成“application/json”作為響應(不過,這是默認值,您可以跳過它)。
@RequestParam
URL中的查詢參數(shù),即?key=value&key1=value1由@RequestParam注釋獲取。這用于函數(shù)的參數(shù)。它有各種選項,如required、defaultValue等。然后將查詢參數(shù)加載到指定的參數(shù)中。
@RequestMapping(value = "/article", method = RequestMethod.GET)
public Article getArticleByName(
@RequestParam(value = "articleName", required = true) String articleName
) {}在上面的例子中,如果我們調(diào)用URL GET localhost/article?articleName=springboot,將在articleName參數(shù)中加載“springboot”。我已經(jīng)把reuired=true,所以如果我們不傳遞articleName,它將向用戶拋出一個錯誤。
@PathVariable
有沒有想過,在不傳遞查詢參數(shù)的情況下,服務器如何知道要加載哪篇文章?看看這篇文章的網(wǎng)址 post URL不包含查詢參數(shù),而是一個普通的斜杠分隔字符串。服務器在PathVariable的幫助下讀取它,它看起來是這樣的,/article/{articleslaug}。替換{articleSlug}的任何字符串都將被視為PathVariable。
@RequestMapping(value = "/article/{articleSlug}", method = RequestMethod.GET)
public Article getArticle(@PathVariable("articleSlug") String articleSlug) {}請記住,{articleSlug}在RequestMapping和PathVariable中應該是相同的(沒有{})。如果不匹配,則無法加載。
@RequestBody
對于POST或PUT方法,您不會通過URL獲取所有數(shù)據(jù),對嗎?這些方法有一個適當?shù)恼埱笾黧w。RequestBody注釋有助于將給定的請求正文自動映射到參數(shù)。主要是JSON到POJO。
@RequestMapping(value = "/article", method = RequestMethod.POST)
public Article createArticle(@RequestBody NewArticlePojo newArticle){}請求主體將自動映射到NewArticlePojo類,并基于鍵填充字段。
REST方法的特定注釋
在上面的解釋中,您一定已經(jīng)看到我使用特定的方法編寫了RequestMapping。但這太多余了。為了解決這個問題,Spring Boot提供了預定義的方法映射。這些只是@RequestMapping的擴展。
@GetMapping
@GetMapping用于將RequestMapping替換為method=RequestMethod。獲取參數(shù)?,F(xiàn)在通過查看,我們知道這是一個GET請求。
@PostMapping和@PutMapping
PostMapping是用method=RequestMethod替換RequestMapping。類似地,PutMapping將用method=RequestMethod替換RequestMethod.PUT
@DeleteMapping
DeleteMapping用method=RequestMethod替換RequestMethod.DELETE
到此這篇關(guān)于Spring Boot Rest常用框架注解詳情簡介的文章就介紹到這了,更多相關(guān)Spring Boot Rest解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java?Long類型轉(zhuǎn)為json后數(shù)據(jù)損失精度的處理方式
這篇文章主要介紹了java?Long類型轉(zhuǎn)為json后數(shù)據(jù)損失精度的處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01
Springboot使用RestTemplate調(diào)用第三方接口的操作代碼
這篇文章主要介紹了Springboot使用RestTemplate調(diào)用第三方接口,我只演示了最常使用的請求方式get、post的簡單使用方法,當然RestTemplate的功能還有很多,感興趣的朋友可以參考RestTemplate源碼2022-12-12
JavaMap兩種遍歷方式keySet與entrySet詳解
這篇文章主要介紹了JavaMap兩種遍歷方式keySet與entrySet,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-03-03
實戰(zhàn)分布式醫(yī)療掛號系統(tǒng)之設置微服務接口開發(fā)模塊
這篇文章主要為大家介紹了實戰(zhàn)分布式醫(yī)療掛號系統(tǒng)之接口開發(fā)醫(yī)院設置微服務模塊,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-04-04

