
如何快速實(shí)現(xiàn)REST API集成以優(yōu)化業(yè)務(wù)流程
ArticleServiceImpl這個(gè)類是一個(gè)很普通的類,只有一個(gè)Spring的注解@Service,標(biāo)識(shí)為一個(gè)bean以便于通過(guò)Spring IoC容器來(lái)管理。我們?cè)賮?lái)看看ArticleController這個(gè)類,其實(shí)用過(guò)Spring MVC的人應(yīng)該都熟悉這幾個(gè)注解,這里簡(jiǎn)單解釋一下:
通過(guò)這個(gè)三個(gè)注解,我們就能輕松的實(shí)現(xiàn)通過(guò)URL給前端返回JSON格式數(shù)據(jù)的功能。不過(guò)大家肯定有點(diǎn)疑惑,這不都是Spring MVC的東西嗎?跟Spring boot有什么關(guān)系?其實(shí)Spring boot的作用就是為我們省去了配置的過(guò)程,其他功能確實(shí)都是Spring與Spring MVC來(lái)為我們提供的,大家應(yīng)該記得Spring boot通過(guò)各種starter來(lái)為我們提供自動(dòng)配置的服務(wù),我們的工程里面之前引入過(guò)這個(gè)依賴:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
這個(gè)是所有Spring boot的web工程都需要引入的jar包,也就是說(shuō)只要是Spring boot的web的工程,都默認(rèn)支持上述的功能。這里我們進(jìn)一步發(fā)現(xiàn),通過(guò)Spring boot來(lái)開(kāi)發(fā)web工程,確實(shí)為我們省了許多配置的工作。
好了,我們現(xiàn)在再來(lái)看看如何實(shí)現(xiàn)Restful API。實(shí)際上Restful本身不是一項(xiàng)什么高深的技術(shù),而只是一種編程風(fēng)格,或者說(shuō)是一種設(shè)計(jì)風(fēng)格。在傳統(tǒng)的http接口設(shè)計(jì)中,我們一般只使用了get和post兩個(gè)方法,然后用我們自己定義的詞匯來(lái)表示不同的操作,比如上面查詢文章的接口,我們定義了article/list.json來(lái)表示查詢文章列表,可以通過(guò)get或者post方法來(lái)訪問(wèn)。而Restful API的設(shè)計(jì)則通過(guò)HTTP的方法來(lái)表示CRUD相關(guān)的操作。因此,除了get和post方法外,還會(huì)用到其他的HTTP方法,如PUT、DELETE、HEAD等,通過(guò)不同的HTTP方法來(lái)表示不同含義的操作。下面是我設(shè)計(jì)的一組對(duì)文章的增刪改查的Restful API:
這里可以看出,URL僅僅是標(biāo)識(shí)資源的路勁,而具體的行為由HTTP方法來(lái)指定。
現(xiàn)在我們?cè)賮?lái)看看如何實(shí)現(xiàn)上面的接口,其他就不多說(shuō),直接看代碼:
@RestController
@RequestMapping("/rest")
public class ArticleRestController {
@Autowired
private ArticleService articleService;
@RequestMapping(value = "/article", method = POST, produces = "application/json")
public WebResponse<Map<String, Object>> saveArticle(@RequestBody Article article) {
article.setUserId(1L);
articleService.saveArticle(article);
Map<String, Object> ret = new HashMap<>();
ret.put("id", article.getId());
WebResponse<Map<String, Object>> response = WebResponse.getSuccessResponse(ret);
return response;
}
@RequestMapping(value = "/article/{id}", method = DELETE, produces = "application/json")
public WebResponse<?> deleteArticle(@PathVariable Long id) {
Article article = articleService.getById(id);
article.setStatus(-1);
articleService.updateArticle(article);
WebResponse<Object> response = WebResponse.getSuccessResponse(null);
return response;
}
@RequestMapping(value = "/article/{id}", method = PUT, produces = "application/json")
public WebResponse<Object> updateArticle(@PathVariable Long id, @RequestBody Article article) {
article.setId(id);
articleService.updateArticle(article);
WebResponse<Object> response = WebResponse.getSuccessResponse(null);
return response;
}
@RequestMapping(value = "/article/{id}", method = GET, produces = "application/json")
public WebResponse<Article> getArticle(@PathVariable Long id) {
Article article = articleService.getById(id);
WebResponse<Article> response = WebResponse.getSuccessResponse(article);
return response;
}
}
我們?cè)賮?lái)分析一下這段代碼,這段代碼和之前代碼的區(qū)別在于:
所以看來(lái)看去,這個(gè)代碼還是跟Spring boot沒(méi)太多的關(guān)系,Spring boot也僅僅是提供自動(dòng)配置的功能,這也是Spring boot用起來(lái)很舒服的一個(gè)很重要的原因,因?yàn)樗那秩胄苑浅7浅P。慊靖杏X(jué)不到它的存在。
代碼寫完了,怎么測(cè)試?除了GET的方法外,都不能直接通過(guò)瀏覽器來(lái)訪問(wèn),當(dāng)然,我們可以直接通過(guò)postman來(lái)發(fā)送各種http請(qǐng)求。不過(guò)我還是比較支持通過(guò)單元測(cè)試類來(lái)測(cè)試各個(gè)方法。這里我們就通過(guò)Junit來(lái)測(cè)試各個(gè)方法:
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = Application.class)
public class ArticleControllerTest {
@Autowired
private ArticleRestController restController;
private MockMvc mvc;
@Before
public void setUp() throws Exception {
mvc = MockMvcBuilders.standaloneSetup(restController).build();
}
@Test
public void testAddArticle() throws Exception {
Article article = new Article();
article.setTitle("測(cè)試文章000000");
article.setType(1);
article.setStatus(2);
article.setSummary("這是一篇測(cè)試文章");
Gson gosn = new Gson();
RequestBuilder builder = MockMvcRequestBuilders
.post("/rest/article")
.accept(MediaType.APPLICATION_JSON) .contentType(MediaType.APPLICATION_JSON_UTF8)
.content(gosn.toJson(article));
MvcResult result = mvc.perform(builder).andReturn(); System.out.println(result.getResponse().getContentAsString());
}
@Test
public void testUpdateArticle() throws Exception {
Article article = new Article();
article.setTitle("更新測(cè)試文章");
article.setType(1);
article.setStatus(2);
article.setSummary("這是一篇更新測(cè)試文章");
Gson gosn = new Gson();
RequestBuilder builder = MockMvcRequestBuilders
.put("/rest/article/1")
.accept(MediaType.APPLICATION_JSON)
.contentType(MediaType.APPLICATION_JSON_UTF8)
.content(gosn.toJson(article));
MvcResult result = mvc.perform(builder).andReturn();
}
@Test
public void testQueryArticle() throws Exception {
RequestBuilder builder = MockMvcRequestBuilders
.get("/rest/article/1")
.accept(MediaType.APPLICATION_JSON) .contentType(MediaType.APPLICATION_JSON_UTF8);
MvcResult result = mvc.perform(builder).andReturn(); System.out.println(result.getResponse().getContentAsString());
}
@Test
public void testDeleteArticle() throws Exception {
RequestBuilder builder = MockMvcRequestBuilders
.delete("/rest/article/1")
.accept(MediaType.APPLICATION_JSON) .contentType(MediaType.APPLICATION_JSON_UTF8);
MvcResult result = mvc.perform(builder).andReturn();
}
}
執(zhí)行結(jié)果這里就不給大家貼了,大家有興趣的話可以自己實(shí)驗(yàn)一下。整個(gè)類要說(shuō)明的點(diǎn)還是很少,主要這些東西都與Spring boot沒(méi)關(guān)系,支持這些操作的原因還是上一篇文章中提到的引入對(duì)應(yīng)的starter:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
因?yàn)橐獔?zhí)行HTTP請(qǐng)求,所以這里使用了MockMvc,ArticleRestController通過(guò)注入的方式實(shí)例化,不能直接new,否則ArticleRestController就不能通過(guò)Spring IoC容器來(lái)管理,因而其依賴的其他類也無(wú)法正常注入。通過(guò)MockMvc我們就可以輕松的實(shí)現(xiàn)HTTP的DELETE/PUT/POST等方法了。
本文講解了如果通過(guò)Spring boot來(lái)實(shí)現(xiàn)Restful的API,其實(shí)大部分東西都是Spring和Spring MVC提供的,Spring boot只是提供自動(dòng)配置的功能。但是,正是這種自動(dòng)配置,為我們減少了很多的開(kāi)發(fā)和維護(hù)工作,使我們能更加簡(jiǎn)單、高效的實(shí)現(xiàn)一個(gè)web工程,從而讓我們能夠更加專注于業(yè)務(wù)本身的開(kāi)發(fā),而不需要去關(guān)心框架的東西。
文章轉(zhuǎn)自微信公眾號(hào)@Java技術(shù)棧
對(duì)比大模型API的內(nèi)容創(chuàng)意新穎性、情感共鳴力、商業(yè)轉(zhuǎn)化潛力
一鍵對(duì)比試用API 限時(shí)免費(fèi)