事務層其實并不雜亂,可是大部分開發人員對其責任并沒有了解清楚,從而使其流浪為一個數據中轉站。
事務層的責任
所以,規劃事務層之前,對事務層的責任要先真實了解清楚。這兒,浪訊舉兩個栗子闡明一下。
第一個是新用戶注冊的比方。注冊時,界面上一般都會要求用戶輸入手機號、驗證碼、暗碼和承認暗碼。可是,API接口一般只會有三個參數:手機號、驗證碼和暗碼,不會有承認暗碼。因而,調用接口之前,暗碼和承認暗碼的一致性查看是有必要的。同時,也要查看這些數據是否為空、手機號是否符合標準、驗證碼是否有用、暗碼有沒有包含了特別字符等。正確姿態便是當一切查看都通過了之后,才調用API接口。最終,調用注冊接口成功后,或許還要再調用一次登錄接口,并或許將用戶登錄信息緩存起來,方便用戶下次發動應用時自動登錄。一切這些都歸于事務邏輯處理,也便是事務層的工作。
第二個是觸及用戶驗證的比方。比方,在一個電商App,當用戶閱讀某個產品,點擊購買時,App首先會判斷用戶是否現已登錄,如未登錄,則會跳轉到登錄頁面讓用戶先登錄。如果現已登錄,但token現已過期,那需求先去獲取新的token,之后才干進行下一步的購物操作。這些邏輯處理,也是事務層的工作。
因而,簡單點說,事務層便是處理事務邏輯,包含數據的查看、事務分支的處理等。比方上面第二個比方,或許很多人就會將用戶是否現已登錄的判斷直接在界面上做處理,當承認登錄后,token也是有用的之后,才調用事務層做購買產品的操作,這便是導致事務層流浪為API的數據中轉站的直接表現。
事務層的交互
只要真實了解了事務層的責任之后,才干有用地規劃事務層與外層的交互接口。
事務層向下,與數據層交互;向上,與展現層交互。
與數據層交互只是調用數據層的接口獲取數據,而與展現層交互則需求供給接口給展現層調用。由于事務處理一般歸于比較耗時的操作,主要在于底層的網絡懇求比較耗時,所以供給給展現層的接口數據結果應該以異步的方式供給,因而,接口上就需求供給個回調參數,回來事務處理之后的結果。
事務層可以說是一個數據加工場,處理中心的事務邏輯。其實,只要了解清楚了事務層的責任,事務層就不難完成。 |