SpringMVC框架和SpringBoot項目中控制器的響應結果深入分析
1.控制器的響應結果
當控制器處理了請求之后,向客戶端響應的結果中,應該至少包含:
- 業(yè)務狀態(tài)碼:通常是數(shù)值類型的,客戶端可以根據(jù)此數(shù)值來判斷操作成功與否,或者,失敗時是哪一種失敗,具體值應該是由服務器端和客戶端協(xié)商的
- 消息:是字符串類型的,客戶端可以將此消息直接顯示在軟件的界面中(例如顯示在網(wǎng)頁中、顯示在手機APP中……),有了這個數(shù)據(jù),客戶端就不必自行組織語言來描述操作結果
由于響應結果只有1個,但是需要同時包含業(yè)務狀態(tài)和消息,應該使用JSON格式來組織這樣的結果,例如:
{
"state": 1,
"message": "添加相冊成功!"
}
或者:
{
"state": 2,
"message": "添加相冊失敗,嘗試添加的相冊名稱已經(jīng)被使用!"
}
2.相關配置
在Spring MVC框架中,當需要響應JSON格式的字符串時,需要:
使用自定義的數(shù)據(jù)類型作為處理請求的方法的返回值類型,并返回自定義數(shù)據(jù)類型的對象
需要在項目中添加jackson-databind
依賴項
- 在
spring-boot-starter-web
中已經(jīng)包含jackson-databind
需要開啟注解驅(qū)動
- 在基于XML配置的Spring MVC項目中,需要在XML配置中添加
<annotation-driven/>
標簽 - 在基于注解配置的Spring MVC項目中,需要在配置類上添加
@EnableWebMvc
注解 - 在Spring Boot項目中,不需要額外配置
則在項目的根包下創(chuàng)建web.JsonResult
類,在類中聲明JSON結果中對應的屬性:
package cn.tedu.csmall.product.web; import lombok.Data; @Data public class JsonResult { private Integer state; private String message; public static JsonResult ok() { JsonResult jsonResult = new JsonResult(); jsonResult.state = ServiceCode.OK; return jsonResult; } }
然后,調(diào)整控制器中處理請求的方法的返回結果:
@ApiOperation("添加相冊") @PostMapping("/add-new") public JsonResult addNew(AlbumAddNewDTO albumAddNewDTO) { albumService.addNew(albumAddNewDTO); return JsonResult.ok(); }
if (response.data.state == 1) { // 成功 } else if (response.data.state == 2) { // 失?。好Q被占用 alert(response.data.message); }
login(){ axios.post("/login",v.user).then(function (response) { if (response.data==1){ location.href="/admin.html" rel="external nofollow" ; //跳轉到后臺管理頁面 }else if(response.data==2){ v.\$message.error("用戶名不存在!"); }else{ v.\$message.error("密碼錯誤!"); } }) }
3.使用枚舉優(yōu)化代碼
在JsonResult
中設計了Integer state
屬性,用于表示“業(yè)務狀態(tài)碼”,由于此值是可以由客戶端和服務器端協(xié)商的值,所以,值的大小不一定是固定的,例如“成功”,可以使用1
表示,也可以使用200
表示,只要協(xié)商一致即可,所以,在應用時,不應該直接將數(shù)值常量賦值到state
屬性上,否則,代碼的可讀性較差!
**反例:**jsonResult.state = 200;
應該將數(shù)值聲明為常量來使用,以增加代碼的可讀性!
**正例:**jsonResult.state = ServiceCode.OK;
在設計方法時,如果使用Integer state
作為參數(shù),方法的調(diào)用者仍可能不使用聲明的常量,而是直接傳入某個未協(xié)商的直接常量值,例如,當設計了fail()
方法時:
public static JsonResult fail(Integer state, String message) { // ... }
則可能調(diào)用時傳入錯誤的值:
JsonResult.fail(99999, e.getMessage());
由于state
對應的值是相對有限的,是可以窮舉的,則可以使用枚舉來解決問題!
package cn.tedu.csmall.product.web; public enum ServiceCode { OK(200), ERR_NOT_FOUND(404), ERR_CONFLICT(409); private Integer value; ServiceCode(Integer value) { this.value = value; } public Integer getValue() { return value; } }
如果將方法的參數(shù)設計為以上枚舉類型,則方法的調(diào)用者只能傳入以上列舉的3個值中的某1個!例如將方法調(diào)整為:
public static JsonResult fail(ServiceCode serviceCode, String message) { // ... }
調(diào)用時則是:
JsonResult.fail(ServiceCode.ERR_CONFLICT, e.getMessage());
到此這篇關于SpringMVC框架和SpringBoot項目中控制器的響應結果深入分析的文章就介紹到這了,更多相關SpringMVC控制器響應內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringMVC中Controller層獲取前端請求參數(shù)的方式匯總
這篇文章主要介紹了SpringMVC中Controller層獲取前端請求參數(shù)的幾種方式,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08spring 自動注入AutowiredAnnotationBeanPostProcessor源碼解析
這篇文章主要介紹了spring自動注入AutowiredAnnotationBeanPostProcessor源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03SpringBoot實現(xiàn)無限級評論回復的項目實踐
本文主要介紹了SpringBoot實現(xiàn)無限級評論回復的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03