如何寫出優(yōu)雅的API
點擊上方?好好學(xué)java?,選擇?星標?公眾號
重磅資訊、干貨,第一時間送達
重磅資訊、干貨,第一時間送達
今日推薦:今天給大家推薦 6 個 Spring Boot 項目,拿來就可以賺錢!
個人原創(chuàng)100W+訪問量博客:點擊前往,查看更多
個人原創(chuàng)100W+訪問量博客:點擊前往,查看更多
轉(zhuǎn)自:碼不動
鏈接:https://www.jianshu.com/p/fa75acba5b07
在移動互聯(lián)網(wǎng),分布式、微服務(wù)盛行的今天,現(xiàn)在項目絕大部分都采用的微服務(wù)框架,前后端分離方式,(題外話:前后端的工作職責越來越明確,現(xiàn)在的前端都稱之為大前端,技術(shù)棧以及生態(tài)圈都已經(jīng)非常成熟;以前后端人員瞧不起前端人員,那現(xiàn)在后端人員要重新認識一下前端,前端已經(jīng)很成體系了)。
一般系統(tǒng)的大致整體架構(gòu)圖如下:

需要說明的是,有些小伙伴會回復(fù)說,這個架構(gòu)太簡單了吧,太low了,什么網(wǎng)關(guān)啊,緩存啊,消息中間件啊,都沒有。因為這篇主要介紹的是API接口,所以我們聚焦點,其他的模塊小伙伴們自行去補充。
接口交互
前端和后端進行交互,前端按照約定請求URL路徑,并傳入相關(guān)參數(shù),后端服務(wù)器接收請求,進行業(yè)務(wù)處理,返回數(shù)據(jù)給前端。
針對URL路徑的restful風(fēng)格,以及傳入?yún)?shù)的公共請求頭的要求(如:app_version,api_version,device等),老顧這里就不介紹了,小伙伴們可以自行去了解,也比較簡單。
著重介紹一下后端服務(wù)器如何實現(xiàn)把數(shù)據(jù)返回給前端?
返回格式
后端返回給前端我們一般用JSON體方式,定義如下:
{
#返回狀態(tài)碼
code:integer,
#返回信息描述
message:string,
#返回值
data:object
}
200 - 請求成功
301 - 資源(網(wǎng)頁等)被永久轉(zhuǎn)移到其它URL
404 - 請求的資源(網(wǎng)頁等)不存在
500 - 內(nèi)部服務(wù)器錯誤

#2000~2999 區(qū)間表示用戶錯誤
#3000~3999 區(qū)間表示接口異常



控制層Controller

美觀優(yōu)化


優(yōu)雅優(yōu)化
2、在業(yè)務(wù)代碼中,成功的時候我們調(diào)用Result.success,異常錯誤調(diào)用Result.failure。是不是很多余
3、上面的代碼,判斷id是否為null,其實我們可以使用hibernate validate做校驗,沒有必要在方法體中做判斷。

實現(xiàn)方案
2、攔截請求,判斷此請求是否需要被@ResponseResult注解
3、核心步驟就是實現(xiàn)接口ResponseBodyAdvice和@ControllerAdvice,判斷是否需要包裝返回值,如果需要,就把Controller接口的返回值進行重寫。





總結(jié)
推薦文章
原創(chuàng)電子書
歷時整整一年總結(jié)的?Java 面試 + Java 后端技術(shù)學(xué)習(xí)指南,這是本人這幾年及校招的總結(jié),各種高頻面試題已經(jīng)全部進行總結(jié),按照章節(jié)復(fù)習(xí)即可,已經(jīng)拿到了大廠offer。
原創(chuàng)思維導(dǎo)圖
掃碼或者微信搜?程序員的技術(shù)圈子?回復(fù)?面試?領(lǐng)取原創(chuàng)電子書和思維導(dǎo)圖。



