国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot 統(tǒng)一請(qǐng)求返回的實(shí)現(xiàn)

瀏覽:2日期:2023-05-06 10:11:40

目前我們的返回是直接把實(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 国产盗摄一区二区三区 | 成人国产在线视频 | 欧美亚洲视频一区 | 亚洲精品视频在线观看免费 | 久久依人| 国产精品网站 夜色 | 国产精品人成人免费国产 | 成人a毛片视频免费看 | 欧美经典成人在观看线视频 | www.色中色| 午夜爱爱毛片xxxx视频免费看 | 欧美一级一片 | 性夜影院爽黄a爽免费看网站 | 久久久久琪琪精品色 | 日韩免费一级毛片欧美一级日韩片 | 亚洲日本一区二区三区在线 | 国产成人精品一区二三区在线观看 | 日日摸夜夜搂人人要 | 蕾丝视频永久在线入口香蕉 | 男人扒开双腿女人爽视频免费 | 一区二区三区在线观看视频 | 亚洲国产一区二区a毛片日本 | 国产精品夫妇久久 | 国产一级二级三级视频 | 国产成人无精品久久久久国语 | 99re7在线精品免费视频 | 亚洲精品资源在线 | fc2久久 | 亚洲国产亚洲片在线观看播放 | 亚洲欧美精品 | 日韩精品中文字幕一区二区三区 | 久久精品亚瑟全部免费观看 | 99久久精品免费看国产一区二区 | 日韩成人免费一级毛片 | caoporen个人免费公开视频 | 久久99精品一级毛片 | 在线观看免费国产成人软件 | 视频精品一区二区三区 | 91精品手机国产露脸 | 一级aaaaaa毛片免费同男同女 | 可以免费看黄的网站 |