SpringBoot 統(tǒng)一請(qǐng)求返回的實(shí)現(xiàn)
目前我們的返回是直接把實(shí)體類扔給請(qǐng)求方,這樣很不友好,一方面沒有統(tǒng)一的格式,二來請(qǐng)求方不知道請(qǐng)求成功與否,沒有一個(gè)可以判斷的東西,也沒有說明性的返回。
本篇就來為所有接口提供一個(gè)統(tǒng)一的友好返回。
確定返回結(jié)構(gòu)
首先,我們先確定好我們接口返回的格式是什么樣的,然后再一步一步實(shí)現(xiàn)下面的。
{
"code": 200,
"msg": "ok",
"data": ""
}
- code 字段表示狀態(tài)碼,調(diào)用方根據(jù)該碼來作為后續(xù)邏輯的依據(jù),比如 code 值為 200 表示操作成功,沒有邏輯錯(cuò)誤,此時(shí)可以提示用戶操作成功等;code 值不為 200 表示操作失敗,比如為 1001 ,表示用戶名已存在,此時(shí)前端做一些相應(yīng)操作。
- msg 字段用來充當(dāng)額外說明,比如上面說的狀態(tài)為 1001,這里的 msg 就可以是 username exists 這樣的說明性文字,幫助調(diào)用方更好的理解。
- data 字段一般是在 code 值為 200 的時(shí)候,返回具體的業(yè)務(wù)數(shù)據(jù),可以是數(shù)組,也可以是對(duì)象。
創(chuàng)建返回碼
根據(jù)上面定的返回結(jié)構(gòu),我們可以把 code 和 msg 字段用枚舉類型整合,在項(xiàng)目中創(chuàng)建 common 目錄,新建 ApiCode.java 如下代碼所示:
package com.foxescap.wxbox.common;
/**
* 全局接口狀態(tài)碼
* @author xfly
*/
public enum ApiCode {
/**
* 通用成功
*/
API_OK(200, "ok"),
/**
* 用戶名已存在
*/
API_USERNAME_EXIST(1001, "username exists");
private final int code;
private final String msg;
ApiCode(int code, String msg) {
this.code = code;
this.msg = msg;
}
public int code() {
return this.code;
}
public String getMsg() {
return this.msg;
}
}
之后每有一個(gè)不同的錯(cuò)誤代碼都需要在這里加上,然后調(diào)用這里的枚舉變量??赡軙?huì)有點(diǎn)繁瑣,但當(dāng)項(xiàng)目逐漸大起來以后,這樣做就能很好的管理狀態(tài)碼。
創(chuàng)建返回類
在項(xiàng)目中創(chuàng)建 common 目錄,新建 HttpResponse.java 文件:
package com.foxescap.wxbox.common;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import lombok.AllArgsConstructor;
import lombok.Data;
import java.io.Serializable;
/**
* @author xfly
* @param <T>
*/
@Data
@AllArgsConstructor
@JsonPropertyOrder({"code", "msg", "data"})
public class ApiResponse<T> implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 自定義返回碼
*/
private int code;
/**
* 自定義返回說明
*/
private String msg;
/**
* 返回?cái)?shù)據(jù)
*/
private T data;
/**
* 成功返回,無數(shù)據(jù)
*
* @return 自定義的 ApiResponse 對(duì)象
*/
public static ApiResponse<Object> success() {
return new ApiResponse<>(ApiCode.API_OK.code(), ApiCode.API_OK.getMsg(), "");
}
/**
* 成功返回,有數(shù)據(jù)
*
* @param object 返回?cái)?shù)據(jù)
* @param <T> 返回?cái)?shù)據(jù)類型
* @return 自定義的 ApiResponse 對(duì)象
*/
public static <T> ApiResponse<T> success(T object) {
return new ApiResponse<>(ApiCode.API_OK.code(), ApiCode.API_OK.getMsg(), object);
}
/**
* 失敗返回
*
* @param apiCode 錯(cuò)誤碼
* @return 自定義的 ApiResponse 對(duì)象
*/
public static ApiResponse<Object> fail(ApiCode apiCode) {
return new ApiResponse<>(apiCode.code(), apiCode.getMsg(), "");
}
}
使用返回類
我們修改一下 Controller 里面的接口返回,現(xiàn)在不是直接返回實(shí)體類了,而是封裝成我們的返回類,再返回給調(diào)用方:
@GetMapping("/user/{username}")
public ApiResponse<User> findUserByUsername(@PathVariable(name = "username") String username) {
return ApiResponse.success(userService.findByUsername(username));
}
到此這篇關(guān)于SpringBoot 統(tǒng)一請(qǐng)求返回的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot 統(tǒng)一請(qǐng)求返回內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
logback和log4j日志框架堆棧信息添加TraceId方式
這篇文章主要介紹了logback和log4j日志框架堆棧信息添加TraceId方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Java?超詳細(xì)講解數(shù)據(jù)結(jié)構(gòu)中的堆的應(yīng)用
堆首先是一個(gè)完全二叉樹,堆分為小根堆和大根堆。小根堆,所有結(jié)點(diǎn)的左右子節(jié)點(diǎn)都不小于根節(jié)點(diǎn);大根堆,所有結(jié)點(diǎn)的左右子節(jié)點(diǎn)都不大于根節(jié)點(diǎn)。優(yōu)先級(jí)隊(duì)列(priorityQueue)底層就是一個(gè)小根堆2022-04-04
解決Intellij IDEA 使用Spring-boot-devTools無效的問題
下面小編就為大家?guī)硪黄鉀QIntellij IDEA 使用Spring-boot-devTools無效的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
Java中正則表達(dá)式的語法以及matches方法的使用方法
正則表達(dá)式(Regular Expression)是一門簡(jiǎn)單語言的語法規(guī)范,是強(qiáng)大、便捷、高效的文本處理工具,這篇文章主要給大家介紹了關(guān)于Java中正則表達(dá)式的語法以及matches方法的使用方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05
Spring Boot 中的自動(dòng)配置autoconfigure詳解
這篇文章主要介紹了Spring Boot 中的自動(dòng)配置autoconfigure詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
springboot基于IDEA環(huán)境熱加載與熱部署教程
這篇文章主要為大家介紹了springboot在IDEA環(huán)境下的熱加載與熱部署教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03
Java創(chuàng)建數(shù)組的幾種方式總結(jié)
下面小編就為大家?guī)硪黄狫ava創(chuàng)建數(shù)組的幾種方式總結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
Maven配置單倉庫與多倉庫的實(shí)現(xiàn)(Nexus)
本文主要介紹了Maven配置單倉庫與多倉庫的實(shí)現(xiàn)(Nexus),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01

