閱讀文本大概須要3分鐘。前端
前言
web
在移動互聯網,分佈式、微服務盛行的今天,如今項目絕大部分都採用的微服務框架,先後端分離方式,(題外話:先後端的工做職責愈來愈明確,如今的前端都稱之爲大前端,技術棧以及生態圈都已經很是成熟;之前後端人員瞧不起前端人員,那如今後端人員要從新認識一下前端,前端已經很成體系了)。後端
通常系統的大體總體架構圖以下:api
須要說明的是,有些小夥伴會回覆說,這個架構太簡單了吧,太low了,什麼網關啊,緩存啊,消息中間件啊,都沒有。由於老顧這篇主要介紹的是API接口,因此咱們聚焦點,其餘的模塊小夥伴們自行去補充。跨域
接口交互緩存
前端和後端進行交互,前端按照約定請求URL路徑,並傳入相關參數,後端服務器接收請求,進行業務處理,返回數據給前端。服務器
針對URL路徑的restful風格,以及傳入參數的公共請求頭的要求(如:app_version,api_version,device等),老顧這裏就不介紹了,小夥伴們能夠自行去了解,也比較簡單。微信
後端服務器如何實現把數據返回給前端?restful
返回格式架構
後端返回給前端咱們通常用JSON體方式,定義以下:
{ #返回狀態碼code:integer, #返回信息描述message:string, #返回值data:object}
CODE狀態碼
:下面是常見的HTTP狀態碼:
200 - 請求成功
301 - 資源(網頁等)被永久轉移到其它URL
404 - 請求的資源(網頁等)不存在
500 - 內部服務器錯誤
#1000~1999 區間表示參數錯誤
#2000~2999 區間表示用戶錯誤
#3000~3999 區間表示接口異常
控制層Controller
一、每一個方法的返回都是Result封裝對象,沒有業務含義 二、在業務代碼中,成功的時候咱們調用Result.success,異常錯誤調用Result.failure。是否是不少餘 三、上面的代碼,判斷id是否爲null,其實咱們可使用hibernate validate作校驗,沒有必要在方法體中作判斷。
這個和咱們平時的代碼是同樣的,很是直觀,直接返回order對象,這樣是否是很完美。那實現方案是什麼呢?
實現方案
一、定義一個註解@ResponseResult,表示這個接口返回的值須要包裝一下 二、攔截請求,判斷此請求是否須要被@ResponseResult註解 三、核心步驟就是實現接口ResponseBodyAdvice和@ControllerAdvice,判斷是否須要包裝返回值,若是須要,就把Controller接口的返回值進行重寫。
攔截器
重寫Controller
☆
往期精彩
☆
01 不要再問我跨域的問題了
關注我天天進步一點點
你點的好看,我都當成了喜歡
本文分享自微信公衆號 - 架構師知音(keepsupersmile)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。