Java接口統(tǒng)一樣式返回模板的實(shí)現(xiàn)
前言
一開始,我們?cè)趯戫?xiàng)目的時(shí)候,前端要什么數(shù)據(jù),我們就返回什么數(shù)據(jù),每個(gè)接口也都寫得不一樣很亂;隨著前后端的分離;對(duì)于代碼規(guī)范的要求也越來越嚴(yán)謹(jǐn);接口都是統(tǒng)一樣式的返回模板;
下面,接受一種我之前用過的返回模板;
一、首先來看下我們的Controller接口
/**
* 獲取用戶信息
* @param token 微信登入者token
* @param id 商品id
* @return 商品詳細(xì)信息
*/
@PostMapping(value = "getUserInfo")
@ResponseBody
public ResultResponse getUserInfo(
@RequestParam(value = "token") String token){
ResultResponse result = new ResultResponse();
//這里獲取用戶信息的類就不貼出來了
User user = userService.getUserByToken(token);
result.setData(user );
return result.setStatus(ResponseCode.SUCCESS);
}
我們可以看出,接口返回的是ResultResponse類;下面來剖析這個(gè)類;
二、統(tǒng)一樣式返回模板ResultResponse剖析
2.1ResultResponse類:
package com.himo.common;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;
/**
* @Author: laixiansong
* @Description: http請(qǐng)求
* @Vesion: 1.0.0
* @Date: 2017/10/17
*/
@Data
public class ResultResponse<T> {
/** 錯(cuò)誤碼 */
private Integer code;
/** 錯(cuò)誤信息 */
private String msg;
@JsonInclude(JsonInclude.Include.NON_NULL)
private T data;
public void setData(T data) {
this.data = data;
}
public ResultResponse setStatus(ResponseCode responseCode){
this.code = responseCode.getCode();
this.msg = responseCode.getDesc();
return this;
}
public String getMsg() {
return msg;
}
}
ResultResponse類包含了錯(cuò)誤碼、錯(cuò)誤信息、返回的對(duì)象json;
2.2枚舉類
從ResultResponse類中我們可以看出,錯(cuò)誤碼和錯(cuò)誤信息是一一對(duì)應(yīng)的,我們用一個(gè)枚舉類ResponseCode來封裝;
ResponseCode:
package com.himo.common;
/**
* @Author: laixiansong
* @Description:
* @Vesion: 1.0.0
* @Date: 2017/10/17
*/
public enum ResponseCode {
SUCCESS(0,"SUCCESS"),
ERROR(1,"ERROR"),
REQUEST_PARAMS_ERROR(1003,"請(qǐng)求參數(shù)錯(cuò)誤"),
NOT_WX_LOGIN(1004,"非微信端登錄"),
WX_LOGIN_PARAMS_ERROR(1005,"微信登錄code錯(cuò)誤"),
NO_LOGIN(1006,"登錄狀態(tài)失效"),
;
private final int code;
private final String desc;
ResponseCode(int code, String desc){
this.code = code;
this.desc = desc;
}
public int getCode() {
return code;
}
public String getDesc() {
return desc;
}
}
我們可以在枚舉類中加入我們想要增加的錯(cuò)誤信息和錯(cuò)誤碼;
這樣就是一個(gè)完成的Java接口返回的模板了;
總結(jié)
技術(shù)在不斷更新?lián)Q代,但是它的基礎(chǔ)沒有變,要想更好的維護(hù)項(xiàng)目,使得代碼更加的美觀和正規(guī),所有接口統(tǒng)一返回統(tǒng)一類是非常有必要的;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java實(shí)現(xiàn)國產(chǎn)sm4加密算法
這篇文章主要介紹了java實(shí)現(xiàn)國產(chǎn)sm4加密算法的步驟,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12
Spring Boot @Async 異步任務(wù)執(zhí)行方法
本篇文章主要介紹了Spring Boot @Async 異步任務(wù)執(zhí)行方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05
解決idea中Terminal終端無法執(zhí)行GIT命令+Terminal 中文亂碼問題
這篇文章主要介紹了解決idea中Terminal終端無法執(zhí)行GIT命令+Terminal 中文亂碼問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
Spring Boot之搞定mongoTemplate的知識(shí)小結(jié)
這篇文章主要介紹了Spring Boot之搞定mongoTemplate的知識(shí)小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
Java處理Markdown格式轉(zhuǎn)換為Word文檔
這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)處理Markdown格式轉(zhuǎn)換為Word文檔,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下2025-03-03
JavaWeb如何實(shí)現(xiàn)本地文件上傳功能
這篇文章主要介紹了JavaWeb如何實(shí)現(xiàn)本地文件上傳功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
詳解Spring中@Valid和@Validated注解用法
本文將以新增一個(gè)員工為功能切入點(diǎn),以常規(guī)寫法為背景,慢慢烘托出?@Valid?和?@Validated?注解用法詳解,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-07-07
Java Session驗(yàn)證碼案例代碼實(shí)例解析
這篇文章主要介紹了Java Session驗(yàn)證碼案例代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06

