溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringBoot如何實(shí)現(xiàn)統(tǒng)一封裝返回前端結(jié)果集

發(fā)布時(shí)間:2022-06-13 11:42:57 來源:億速云 閱讀:713 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了SpringBoot如何實(shí)現(xiàn)統(tǒng)一封裝返回前端結(jié)果集的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇SpringBoot如何實(shí)現(xiàn)統(tǒng)一封裝返回前端結(jié)果集文章都會(huì)有所收獲,下面我們一起來看看吧。

我們?nèi)绾畏庋b這個(gè)結(jié)果?我們應(yīng)該注意返回到前端的數(shù)據(jù)中包含的信息。

一般來說,首先,這次必須有一個(gè)code來表示接口的狀態(tài)。例如,0表示成功,1表示失敗,2表示必須傳遞錯(cuò)誤的參數(shù),4表示系統(tǒng)異常,依此類推。這只是一個(gè)簡單的例子。許多人可能會(huì)有疑問。HTTP協(xié)議本身已經(jīng)有了相應(yīng)的返回代碼定義。 例如: 200表示成功, 500表示服務(wù)器錯(cuò)誤, 404表示找不到頁面。

例如,200表示請(qǐng)求成功,但它不能描述請(qǐng)求中的業(yè)務(wù)結(jié)果。 例如,用戶名已經(jīng)存在,事實(shí)上,業(yè)務(wù)并不成功,但HTTP的結(jié)果肯定是200, 因此我們需要一個(gè)代碼來描述我們的業(yè)務(wù)狀態(tài)。

除了代碼之外,還有一些提示信息,如操作成功、系統(tǒng)異常、用戶名已經(jīng)存在等,所以我們添加了一個(gè)message字段。

此外,還有我們的核心數(shù)據(jù)。例如,我根據(jù)ID獲取數(shù)據(jù)。此數(shù)據(jù)的具體內(nèi)容必須返回到前端,因此必須有數(shù)據(jù)。此數(shù)據(jù)使用什么類型?這種類型必須是多樣的,所以我們需要使用統(tǒng)一的父類,以便對(duì)象可以接收所有類型。當(dāng)然,我們可以使用一些通用方法來方便操作。

然后還有我們的核心數(shù)據(jù)。例如,我根據(jù)ID獲取數(shù)據(jù)。此數(shù)據(jù)的具體內(nèi)容必須返回到前端,因此必須有數(shù)據(jù)。此數(shù)據(jù)使用什么類型?這種類型必須是多樣的,所以我們需要使用統(tǒng)一的父類,以便對(duì)象可以接收所有類型。當(dāng)然,我們可以使用通用方法來方便操作。

主要代碼展示:

public class Result<T> implements Serializable {
   private static final long serialVersionUID = -3960261604608758516L;
  private int code;
  private String msg;
  private T data;
  public static <T> Result<T> success() {
        return new Result<>();
    }
 
    /**
     * 成功,默認(rèn)狀態(tài)碼,返回消息,自定義返回?cái)?shù)據(jù)
     * @param data 自定義返回?cái)?shù)據(jù)
     * @param <T>  返回類泛型,不能為String
     * @return 通用返回Result
     */
    public static <T> Result<T> success(T data) {
        return new Result<>(data);
    }
 
     /**
     * 成功,默認(rèn)狀態(tài)碼,自定義返回消息,返回?cái)?shù)據(jù)
     * @param msg  自定義返回消息
     * @param data 自定義返回?cái)?shù)據(jù)
     * @param <T>  返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> success(String msg, T data) {
        return new Result<>(msg, data);
    }
           /**
     * 成功,默認(rèn)狀態(tài)碼,自定義返回消息,無返回?cái)?shù)據(jù)
     *
     * @param msg 自定義返回消息
     * @param <T> 返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> success(String msg) {
        return new Result<>(msg);
    }
     /**
     * 失敗,默認(rèn)狀態(tài)碼,返回消息,無返回?cái)?shù)據(jù)
     * @param <T> 返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> error() {
        return new Result<>(ResultCode.ERROR);
    }
     /**
     * 失敗,默認(rèn)狀態(tài)碼,自定義返回消息,無返回?cái)?shù)據(jù)
     * @param <T> 返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> error(String msg) {
        return new Result<>(ResultCode.ERROR.getCode(), msg);
    }
     /**
     * 失敗,自定義狀態(tài)碼,返回消息,無返回?cái)?shù)據(jù)
     * @param code 自定義狀態(tài)碼
     * @param msg  自定義返回消息
     * @param <T>  返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> error(int code, String msg) {
        return new Result<>(code, msg);
    }
     /**
     * 失敗,使用CodeMsg狀態(tài)碼,返回消息,無返回?cái)?shù)據(jù)
      * @param resultCode CodeMsg,參數(shù)如下:
     *                   <p> code 狀態(tài)碼
     *                   <p> msg  返回消息
     * @param <T>        返回類泛型
     * @return 通用返回Result
     */
    public static <T> Result<T> error(ResultCode resultCode) {
        return new Result<>(resultCode);
    }
     /**
     * 成功構(gòu)造器,無返回?cái)?shù)據(jù)
     */
    private Result() {
        this(ResultCode.SUCCESS);
    }
     /**
     * 成功構(gòu)造器,自定義返回?cái)?shù)據(jù)
     * @param data 返回?cái)?shù)據(jù)
     */
    private Result(T data) {
        this(ResultCode.SUCCESS, data);
    }
     /**
     * 成功構(gòu)造器,自定義返回消息,無返回?cái)?shù)據(jù)
     * @param msg 返回消息
     */
    private Result(String msg) {
        this(ResultCode.SUCCESS.getCode(), msg);
    }
           /**
     * 構(gòu)造器,自定義狀態(tài)碼,返回消息
     * @param code 狀態(tài)碼
     * @param msg  返回消息
     */
    private Result(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }
     /**
     * 成功構(gòu)造器,自定義返回信息,返回?cái)?shù)據(jù)
     * @param msg  返回信息
     * @param data 返回?cái)?shù)據(jù)
     */
    private Result(String msg, T data) {
        this(ResultCode.SUCCESS.getCode(), msg, data);
    }
 
    /**
     * 構(gòu)造器,自定義狀態(tài)碼,返回消息,返回?cái)?shù)據(jù)
     * @param code 狀態(tài)碼
     * @param msg  返回消息
     * @param data 返回?cái)?shù)據(jù)
     */
    private Result(int code, String msg, T data) {
        this(code, msg);
        this.data = data;
    }
            /**
     * 構(gòu)造器,使用CodeMsg狀態(tài)碼與返回信息,自定義返回?cái)?shù)據(jù)
     * @param resultCode CodeMsg,參數(shù)如下:
     *                   <p> code 狀態(tài)碼
     *                   <p> msg  返回消息
     * @param data       返回?cái)?shù)據(jù)
     */
    private Result(ResultCode resultCode, T data) {
        this(resultCode);
        this.data = data;
    }
  
    /**
     * 構(gòu)造器,使用CodeMsg狀態(tài)碼與返回信息
     * @param resultCode CodeMsg,參數(shù)如下:
     *                   <p> code 狀態(tài)碼
     *                   <p> msg  返回消息
     */
    private Result(ResultCode resultCode) {
        this(resultCode.getCode(), resultCode.getMsg());
    }
 
}

還需要定義幾個(gè)常見的錯(cuò)誤

@Builder
public class ResultCode implements Serializable {
     private static final long serialVersionUID = -6269841958947880397L;
     /** 狀態(tài)碼*/
    private int code;
     /**狀態(tài)信息*/
    private String msg;
     /** 默認(rèn)成功*/
    public final static ResultCode SUCCESS = dispose(ResultCodeEnum.SUCCESS);
    /**默認(rèn)失敗*/
   public final static ResultCode ERROR = dispose(ResultCodeEnum.ERROR);
    /**通用業(yè)務(wù)異常*/
    public final static ResultCode BIZ_ERROR = dispose(ResultCodeEnum.BIZ_ERROR);
    /**文件超出最大限制*/
    public final static ResultCode FILE_OUT_MAX = dispose(ResultCodeEnum.FILE_OUT_MAX);
    /**文件格式不正確*/
    public final static ResultCode FILE_FORMAT_ERROR = dispose(ResultCodeEnum.FILE_FORMAT_ERROR);
    /** 參數(shù)錯(cuò)誤*/
    public final static ResultCode PARAM_ERROR = dispose(ResultCodeEnum.PARAM_ERROR);
    /**Json解析異常*/
    public final static ResultCode JSON_FORMAT_ERROR = dispose(ResultCodeEnum.JSON_FORMAT_ERROR);
    /** Sql解析異常*/
    public final static ResultCode SQL_ERROR = dispose(ResultCodeEnum.SQL_ERROR);
    /**網(wǎng)絡(luò)超時(shí)*/
    public final static ResultCode NETWORK_TIMEOUT = dispose(ResultCodeEnum.NETWORK_TIMEOUT);
    /** 未知的接口*/
    public final static ResultCode UNKNOWN_INTERFACE = dispose(ResultCodeEnum.UNKNOWN_INTERFACE);
    /**請(qǐng)求方式不支持*/
    public final static ResultCode REQ_MODE_NOT_SUPPORTED = dispose(ResultCodeEnum.REQ_MODE_NOT_SUPPORTED);
    /**系統(tǒng)異常*/
    public final static ResultCode SYS_ERROR = dispose(ResultCodeEnum.SYS_ERROR);
    private static ResultCode dispose(ResultCodeEnum codeEnum) {
        return ResultCode.builder().code(codeEnum.getCode()).msg(codeEnum.getMsg()).build();
    }
     public ResultCode(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }
}

關(guān)于“SpringBoot如何實(shí)現(xiàn)統(tǒng)一封裝返回前端結(jié)果集”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“SpringBoot如何實(shí)現(xiàn)統(tǒng)一封裝返回前端結(jié)果集”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI