那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

讓代碼變得更簡潔的小技巧

科技綠洲 ? 來源:Java技術(shù)指北 ? 作者:Java技術(shù)指北 ? 2023-10-08 14:46 ? 次閱讀

目前很多項(xiàng)目都是前后端分離,前后端會事先約定好返回格式。那么后端如何做,才能優(yōu)雅的返回統(tǒng)一格式呢,接下來,請大家跟著我,一步步來實(shí)現(xiàn)。

1. 直接返回結(jié)果

先看一下最基本的例子,直接將結(jié)果原封不動(dòng)返回:

@Data
@AllArgsConstructor
@JsonIgnoreProperties(ignoreUnknown = true)
public class TestVo {

    private static final long serialVersionUID = 1L;

    @Schema(name = "姓名")
    private String name;

    @Schema(name = "年齡")
    private Integer age;

}
@RestController
@RequestMapping(value = "/test")
public class TestApi {

    @GetMapping("/simple")
    public TestVo simple() {
        TestVo testVo = new TestVo("張三", 30);
        return testVo;
    }
}

返回結(jié)果:

{
    "name": "張三",
    "age": 30
}

2. 約定返回格式

假如已經(jīng)與前端開發(fā)妹子約定好了格式,比如:

{
    "code": 0,
    "msg": "錯(cuò)誤信息",
    "data": 實(shí)際返回結(jié)果
}

那么我們首先需要編寫一個(gè)封裝結(jié)果類Result。為了方便封裝,在這個(gè)類中增加一個(gè)success方法:

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class Result< T > implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 返回編碼
     */
    private Integer code;

    /**
     * 編碼描述
     */
    private String msg;

    /**
     * 業(yè)務(wù)數(shù)據(jù)
     */
    private T data;

    /**
     * 返回成功結(jié)果對象
     *
     * @param data
     * @param < T >
     * @return
     */
    public static < T > Result< T > success(T data) {
        Result result = new Result();
        result.setCode(0);
        result.setMsg("success");
        result.setData(data);
        return result;
    }
}

3. 返回統(tǒng)一格式結(jié)果

后臺接口代碼微調(diào)一下,返回值改為Result,泛型為原返回值的類型:

@RestController
@RequestMapping(value = "/test")
public class TestApi {

    @GetMapping("/withResult")
    public Result< TestVo > withResult() {
        TestVo testVo = new TestVo("張三", 30);
        return Result.success(testVo);
    }
}

返回結(jié)果:

{
    "code": 0,
    "msg": "success",
    "data": {
        "name": "張三",
        "age": 30
    }
}

至此,返回結(jié)果完美符合格式。

但是這樣的代碼并不算簡潔:每個(gè)接口的返回值都必須是Result<>,并且return的時(shí)候都要用Result.success()方法封裝一下。

那么,有沒有更優(yōu)雅的方法?我們繼續(xù)往下看:

4. 切片封裝統(tǒng)一格式

  1. 編寫注解

實(shí)際使用場景中,并不是所有接口都需要統(tǒng)一格式。我們這里使用一個(gè)注解作為開關(guān),按需控制接口返回格式。

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ApiResult {
    String value() default "";

    int successCode() default 0;

    String successMsg() default "success";

    Class< ? extends IResult > resultClass() default Result.class;
}
  1. 編寫ControllerAdvice
@ControllerAdvice
public class MyResponseBodyAdvice implements ResponseBodyAdvice {

    protected boolean isStringConverter(Class converterType) {
        return converterType.equals(StringHttpMessageConverter.class);
    }

    protected boolean isApiResult(MethodParameter returnType) {
        return returnType.hasMethodAnnotation(ApiResult.class);
    }

    @Override
    public boolean supports(MethodParameter returnType, Class converterType) {
        return !isStringConverter(converterType) && isApiResult(returnType);
    }

    @Override
    public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType,
                                Class selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) {
        //關(guān)鍵                         
        return Result.success(body);
    }

}

這里有一點(diǎn)要 注意 ,這個(gè)advice中supports方法中判斷返回結(jié)果類型必須為非String類型。如果返回結(jié)果為String類型,那么result要轉(zhuǎn)為json字符串后再返回,需要再寫一個(gè)advice。

  1. 見證奇跡的時(shí)刻到了
@ApiResult
@GetMapping("/withResultHide")
public TestVo withResultHide() {
    TestVo testVo = new TestVo("張三", 30);
    return testVo;
}

這段代碼與最開始一樣,并沒有返回Result,僅僅加上了@ApiResult注解,我們看返回結(jié)果:

{
    "code": 0,
    "msg": "success",
    "data": {
        "name": "張三",
        "age": 30
    }
}

大功告成!

以上只是最精簡的例子,實(shí)際使用中還結(jié)合了 統(tǒng)一異常封裝、自定義返回格式 等功能。我們注意到@ApiResult注解中,有三個(gè)參數(shù):successCode、successMsg、resultClass,就是為了自定義返回格式預(yù)留的,下面再看兩個(gè)場景:

5. 自定義返回格式

場景1:返回成功時(shí)code為200

如果個(gè)別接口的返回格式與默認(rèn)格式相同,但是要求code等于200時(shí)才代表成功,那么修改下successCode參數(shù)即可:

@ApiResult(successCode = 200, successMsg = "ok")
@GetMapping("/withResultHide")
public TestVo withResultHide() {
    TestVo testVo = new TestVo("張三", 30);
    return testVo;
}

返回成功時(shí),結(jié)果中的code和msg都變?yōu)樵O(shè)置的值:

{
    "code": 200,
    "msg": "ok",
    "data": {
        "name": "張三",
        "age": 30
    }
}
場景2:自定義返回格式

如果某個(gè)接口的返回格式不是默認(rèn)的返回格式,比如約定返回returnCode、returnDesc、data(對應(yīng)默認(rèn)的code、msg、data)。那么則需要新增一個(gè)返回結(jié)果類,比如ReturnResult:

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class ReturnResult< T > implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 返回編碼
     */
    private String returnCode;

    /**
     * 編碼描述
     */
    private String returnDesc;

    /**
     * 業(yè)務(wù)數(shù)據(jù)
     */
    private T data;

    /**
     * 返回成功結(jié)果對象
     *
     * @param data
     * @param < T >
     * @return
     */
    public static < T > ReturnResult< T > success(T data) {
        ReturnResult result = new ReturnResult();
        result.setReturnCode(0);
        result.setReturnDesc("success");
        result.setData(data);
        return result;
    }
}

然后修改接口上的@ApiResult注解中的resultClass屬性

@ApiResult(resultClass = ReturnResult.class)
@GetMapping("/withResultHide")
public TestVo withResultHide() {
    TestVo testVo = new TestVo("張三", 30);
    return testVo;
}

這時(shí),返回結(jié)果就變?yōu)橄胍母袷搅耍?/p>

{
    "returnCode": "0",
    "returnDesc": "success",
    "data": {
        "name": "張三",
        "age": 30
    }
}

小結(jié)

只要按照上面一步步改造,即可實(shí)現(xiàn)統(tǒng)一返回格式,既簡潔、又優(yōu)雅。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8691

    瀏覽量

    151911
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4825

    瀏覽量

    69040
收藏 人收藏

    評論

    相關(guān)推薦

    【公測】新版文檔中心上線,開發(fā)變得簡單

    11月3日,機(jī)智云文檔中心全新改版,新增和優(yōu)化了 “X” 功能,快速掌握物聯(lián)網(wǎng)開發(fā)技術(shù)變得非常簡單。1、新增導(dǎo)航欄。結(jié)構(gòu)不明,不知道什么是云端、APP開發(fā)、設(shè)備端聯(lián)網(wǎng)開發(fā)在哪?新增導(dǎo)航欄,一目了然
    發(fā)表于 11-07 14:27

    傳感器變得簡單

    的傳感器,下一步就是為傳感器編寫應(yīng)用程序代碼。并非直接跳到微控制器的代碼,而是在Python編寫應(yīng)用程序代碼。許多總線 工具在編寫腳本(writing scripts)配置了插件(plug-in)和范例碼
    發(fā)表于 11-07 15:24

    智能化電能計(jì)量技術(shù)如何世界變得環(huán)保

    智能化電能計(jì)量技術(shù)提升能效,世界變得環(huán)保
    發(fā)表于 02-01 07:49

    單片機(jī)編程中怎么效率提高,代碼簡潔?

    單片機(jī)編程中怎么效率提高,代碼簡潔
    發(fā)表于 10-20 06:19

    怎么我筆記本電池變得持久?

    怎么我筆記本電池變得持久? 1.在使用筆記本電腦之前認(rèn)真閱讀使用手冊的電池保養(yǎng)部分;   2.第一次充電時(shí),你應(yīng)該連續(xù)地把電池
    發(fā)表于 01-20 14:12 ?595次閱讀

    如何編寫高效簡潔的C語言代碼

      引言:   編寫高效簡潔的C語言代碼,是許多軟件工程師追求的目標(biāo)。本文就工作中的一些體會和經(jīng)驗(yàn)做相關(guān)的闡述,不對的地方請各位指教。   第1招:以
    發(fā)表于 08-19 14:38 ?844次閱讀

    辯論賽:智能家居生活變得簡單還是麻煩

    如果兩支隊(duì)伍進(jìn)行一場“智能家居生活變得簡單還是麻煩”的辯論賽,會是什么情景? 如果這場辯論賽在本世紀(jì)之前開始,那么很大可能會無疾而終
    發(fā)表于 04-27 08:56 ?1545次閱讀

    微軟官宣正研究用戶升級Windows10變得簡便的方法

    事實(shí)上,微軟正在通過一步步的努力,用戶升級Windows 10變得容易,比如日前發(fā)布的Build 19536版本更新中,微軟已經(jīng)官宣正在研究簡便的方法,來安裝驅(qū)動(dòng)程序和每月非安全質(zhì)量更新。
    的頭像 發(fā)表于 12-25 10:36 ?1915次閱讀

    數(shù)字式萬用表的測附件測量變得容易

    對數(shù)字式萬用表的一個(gè)十分重要的要求是,它要能夠使用各種各樣的附件。很多附件可增加數(shù)字式萬用表的測量范圍和用途,同時(shí)測量變得容易。
    發(fā)表于 07-15 14:08 ?1010次閱讀

    如何MR變得落地、更易用

    科技 COO 程凌,通過回顧4年以來的創(chuàng)業(yè)開拓與研發(fā)創(chuàng)新歷程,闡釋如何 MR 變得落地、更易用,以及技術(shù)升級所帶來的多重價(jià)值。同時(shí),還結(jié)合客戶案例,分享 SaaS 服務(wù)的實(shí)際效能。
    的頭像 發(fā)表于 03-11 09:19 ?1404次閱讀

    關(guān)于Python 加速工具的選單

    ? 這篇文章會提供一些 優(yōu)化代碼的工具 。會代碼變得簡潔,或者
    的頭像 發(fā)表于 07-07 11:19 ?425次閱讀

    分享一些Python代碼加速工具

    這篇文章會提供一些優(yōu)化代碼的工具。會代碼變得簡潔,或者
    發(fā)表于 07-07 11:18 ?414次閱讀

    視頻處理器投影變得簡單

    ,完美的把各組投影機(jī)的投影畫面進(jìn)行無縫邊緣整合,而實(shí)現(xiàn)亮、更大、清的顯示。 在投影技術(shù)上的改進(jìn)與創(chuàng)新成為信息科技技術(shù)新的突破發(fā)向,而視頻處理器的問世則投影變得更加簡單,我們總結(jié)了
    的頭像 發(fā)表于 08-24 16:37 ?869次閱讀
    視頻處理器<b class='flag-5'>讓</b>投影<b class='flag-5'>變得</b><b class='flag-5'>更</b>簡單

    Python開發(fā)者必備工具集

    這篇文章會提供一些優(yōu)化代碼的工具。會代碼變得簡潔,或者
    的頭像 發(fā)表于 10-16 11:14 ?505次閱讀

    “可靠”變得“更快安全”的數(shù)據(jù)傳輸協(xié)議:SCTP

    SCTP(Stream Control Transmission Protocol,流控傳輸協(xié)議)的出現(xiàn),并不是萬丈高樓平地起,而是站在TCP這個(gè)巨人肩膀上,數(shù)據(jù)傳輸從“可靠”變得“更快安全”。
    的頭像 發(fā)表于 12-28 17:25 ?1504次閱讀
    <b class='flag-5'>讓</b>“可靠”<b class='flag-5'>變得</b>“更快<b class='flag-5'>更</b>安全”的數(shù)據(jù)傳輸協(xié)議:SCTP
    大赢家博彩网| 诸子百家乐官网的玩法技巧和规则 | 家百家乐破解软件| 高档百家乐官网桌| 百家乐官网能战胜吗| 网上娱乐城老虎机| 大发888娱乐游戏博彩| 什么叫百家乐的玩法技巧和规则| 乐百家百家乐游戏| 百家乐从哪而来| 百家乐官网平注常赢玩法更| 游戏机百家乐官网下载| 澳门百家乐官网赌| 连环百家乐官网怎么玩| 百家乐官网破解| 菲律宾百家乐官网开户| 百家乐官网走势图| 真人百家乐官网软件云南景| 茅台百家乐官网的玩法技巧和规则| 百家乐官网技巧微笑心法| HG百家乐官网大转轮| 百家乐官网长t恤| 百家乐辅助工具| 百家乐网上投注网站| 什么百家乐平注法| 百家乐桌码合| 百家乐网站| 德州扑克单机版| 皇家国际娱乐| 宿松县| 百家乐官网有赢钱公式吗| 百家乐官网桌子豪华| 博之道百家乐官网的玩法技巧和规则| 大发888手机好玩吗| 足球博彩| 凯旋门百家乐官网娱乐城| 百家乐官网赌博故事| 网上百家乐官网真的假| 真人百家乐信誉| 荷规则百家乐的玩法技巧和规则| 大发888网页版出纳|