Spring Boot構(gòu)建優(yōu)雅的RESTful接口過(guò)程詳解
RESTful
相信在座的各位對(duì)于RESTful都是略有耳聞,那么RESTful到底是什么呢?
REST(Representational State Transfer)表述性狀態(tài)轉(zhuǎn)移是一組架構(gòu)約束條件和原則。滿足這些約束條件和原則的應(yīng)用程序或設(shè)計(jì)就是RESTful。需要注意的是,REST是設(shè)計(jì)風(fēng)格而不是標(biāo)準(zhǔn)。REST通常基于使用HTTP,URI,和XML(標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言下的一個(gè)子集)以及HTML(標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言下的一個(gè)應(yīng)用)這些現(xiàn)有的廣泛流行的協(xié)議和標(biāo)準(zhǔn)。
也許這段話有些晦澀難懂,換個(gè)角度我們來(lái)解釋一下RESTful。
首先來(lái)看一組例子:
//查詢所有人員(傳統(tǒng)) localhost:8088/api/user/findAll 請(qǐng)求方式:GET //查詢所有人員(RESTful) localhost:8088/api/users 請(qǐng)求方式:GET //修改人員(傳統(tǒng)) localhost:8088/api/user/update 請(qǐng)求方式:POST //修改人員(RESTful) localhost:8088/api/users 請(qǐng)求方式:PUT //添加人員(傳統(tǒng)) localhost:8088/api/user/add 請(qǐng)求方式:POST //添加人員(RESTful) localhost:8088/api/users 請(qǐng)求方式:POST //刪除人員(傳統(tǒng)) localhost:8088/api/user/delete 請(qǐng)求方式:DELETE //刪除人員(RESTful) localhost:8088/api/users 請(qǐng)求方式:DELETE
我們通常稱地址欄中輸入的地址為URI(Uniform Resource Identifier),翻譯成中文就是統(tǒng)一資源標(biāo)識(shí)符。
資源,我們?cè)跒g覽器頁(yè)面上看到的東西都可以稱之為資源,比如圖片,文字,語(yǔ)音等等。
而URI就是用于定位這些資源的位置的,RESTful風(fēng)格的接口中只出現(xiàn)了表示資源的名詞,關(guān)于這個(gè)資源的操作,通過(guò)HTTP內(nèi)置的幾種請(qǐng)求類型來(lái)區(qū)分。同一個(gè)路徑localhost:8088/api/users,因?yàn)檎?qǐng)求方式的不同,而去找尋不同的接口,完成對(duì)資源狀態(tài)的轉(zhuǎn)變。
總結(jié)一下,REST就是指對(duì)同一個(gè)URI的資源的不同請(qǐng)求方式(GET,POST,PUT,DELETE)(表述)下的做出的不同的操作(查,增,改,刪),改變的是資源的狀態(tài),即表述性狀態(tài)轉(zhuǎn)移。 一個(gè)符合REST風(fēng)格的URI就可以稱之一個(gè)RESTful的接口。
看到這里,相信RESTful已經(jīng)了解的差不多了,下面我們來(lái)看看在Spring Boot中如何去使用
SpringMVC 構(gòu)建RESTful接口
SpringMVC中給我們提供了一些注解,可以幫助我們?nèi)?gòu)建RESTful的接口,下面來(lái)直接看代碼:
package indi.viyoung.viboot.restful.controller; import indi.viyoung.viboot.restful.entity.User; import indi.viyoung.viboot.restful.service.UserService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.List; /** * <p> * 前端控制器 * </p> * * @author viyoung * @since 2019-01-23 */ @RestController @RequestMapping("/users") @Slf4j @CrossOrigin public class UserController { @Autowired private UserService userService; @GetMapping public List<User> get() { log.info("GET方法執(zhí)行。。。"); return userService.list(); } @GetMapping(value = "/{id}") public User get(@PathVariable String id) { log.info("GET..{}...方法執(zhí)行。。。",id); return userService.getById(id); } @PostMapping public void post() { log.info("POST方法執(zhí)行。。。"); } @PutMapping public void put() { log.info("PUT方法執(zhí)行。。。"); } @DeleteMapping public void delete() { log.info("DELETE方法執(zhí)行。。。"); } }
下面我們也許需要一個(gè)前端的工程或者POSTMAN等測(cè)試接口的工具來(lái)發(fā)送不同的請(qǐng)求,我這里已經(jīng)寫好了一個(gè)前端的基于vue的工程,有需要的可以去下載一下:viboot-front。記得順手點(diǎn)個(gè)star喲~
依次點(diǎn)擊這五個(gè)按鈕,可以看到后臺(tái)的控制臺(tái)分別打印出了不同的語(yǔ)句:
原創(chuàng)文章,才疏學(xué)淺,如有不對(duì)之處,萬(wàn)望告知!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Maven構(gòu)建Hadoop項(xiàng)目的實(shí)踐步驟
本文主要介紹了Maven構(gòu)建Hadoop項(xiàng)目的實(shí)踐步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06學(xué)習(xí)Java之IO流的基礎(chǔ)概念詳解
這篇文章主要給大家介紹了Java中的IO流,我們首先要搞清楚一件事,就是為什么需要IO流這個(gè)東西,但在正式學(xué)習(xí)IO流的使用之前,小編有必要帶大家先了解一下IO流的基本概念,需要的朋友可以參考下2023-09-09SpringBoot如何使用slf4j日志及其項(xiàng)目配置、MVC支持
這篇文章主要介紹了SpringBoot如何使用slf4j日志及其項(xiàng)目配置、MVC支持,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05如何解決java.lang.ClassNotFoundException: com.mysql.jdbc.Dr
這篇文章主要介紹了如何解決java.lang.ClassNotFoundException: com.mysql.jdbc.Driver問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12通過(guò)代理類實(shí)現(xiàn)java連接數(shù)據(jù)庫(kù)(使用dao層操作數(shù)據(jù))實(shí)例分享
java通過(guò)代理類實(shí)現(xiàn)數(shù)據(jù)庫(kù)DAO操作代碼分享,大家參考使用吧2013-12-12詳解如何在Java中重寫equals()和hashCode()方法
在 Java 中,equals() 和 hashCode() 方法是 Object 類中定義的重要方法,它們用于比較對(duì)象的相等性以及計(jì)算對(duì)象的哈希值,本文將詳細(xì)介紹如何在 Java 中重寫 equals() 和 hashCode() 方法,并討論其最佳實(shí)踐,需要的朋友可以參考下2024-08-08Java Web實(shí)現(xiàn)session過(guò)期后自動(dòng)跳轉(zhuǎn)到登陸頁(yè)功能【基于過(guò)濾器】
這篇文章主要介紹了Java Web實(shí)現(xiàn)session過(guò)期后自動(dòng)跳轉(zhuǎn)到登陸頁(yè)功能,涉及java過(guò)濾器針對(duì)session的判斷與跳轉(zhuǎn)相關(guān)操作技巧,需要的朋友可以參考下2017-11-11java實(shí)現(xiàn)學(xué)生宿舍系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)學(xué)生宿舍系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03