[Spring cloud 一步步實現廣告系統] 4. 通用代碼模塊設計

来源:https://www.cnblogs.com/zhangpan1244/archive/2019/07/27/11256501.html
-Advertisement-
Play Games

一個大的系統,在代碼的復用肯定是必不可少的,它能解決: 1. 統一的響應處理(可以對外提供統一的響應對象包裝) 2. 統一的異常處理(可以將業務異常統一收集處理) 3. 通用代碼定義、配置定義(通用的配置信息放在統一的代碼管理中,便於維護和更新) 創建項目 POM文件 項目結構 vo (統一響應對象 ...


一個大的系統,在代碼的復用肯定是必不可少的,它能解決:

  1. 統一的響應處理(可以對外提供統一的響應對象包裝)

UTOOLS1564230299519.png

  1. 統一的異常處理(可以將業務異常統一收集處理)

UTOOLS1564230319631.png

  1. 通用代碼定義、配置定義(通用的配置信息放在統一的代碼管理中,便於維護和更新)

創建項目mscx-ad-common

POM文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>mscx-ad</artifactId>
        <groupId>com.sxzhongf</groupId>
        <version>1.0-SNAPSHOT</version>
        <relativePath>../pom.xml</relativePath>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <packaging>jar</packaging>

    <groupId>com.sxzhongf</groupId>
    <artifactId>mscx-ad-common</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>Common-Service</name>
    <description>公共邏輯 and 幫助類</description>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- fastjson是阿裡巴巴的開源JSON解析庫,它可以解析JSON格式的字元串,支持將Java Bean序列化為JSON字元串,也可以從JSON字元串反序列化到JavaBean -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.58</version>
        </dependency>
        <!--  -->
        <dependency>
            <groupId>commons-codec</groupId>
            <artifactId>commons-codec</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
        </dependency>
    </dependencies>
        <!--maven編譯插件-->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

項目結構

  • vo (統一響應對象package)

  • advice (bean 增強package )

    Spring支持五種類型的增強或通知(Advice)
    • Before(方法執行前) org.apringframework.aop.MethodBeforeAdvice
    • AfterReturning(方法返回後) org.springframework.aop.AfterReturningAdvice
    • After-throwing(異常拋出後) org.springframework.aop.ThrowsAdviceArround環繞,即方法前後 org.aopaliance.intercept.MethodInterceptor
      引介,不常用 org.springframework.aop.IntroductionInterceptor
      具體可參考:細說advice,advisor
  • annotation
  • config
  • exception
  • utils
  • export

    通用響應編碼
  1. 創建通用返回對象
/**
* @Data是下屬註解的組合註解
* 
* @see Getter
* @see Setter
* @see RequiredArgsConstructor
* @see ToString
* @see EqualsAndHashCode
* @see lombok.Value 
*/
@Data
@NoArgsConstructor //無參構造函數
@AllArgsConstructor //全參構造函數
public class CommonResponse<T> implements Serializable {
   private Integer code = 0;
   private String message = "success";
   /**
    * 具體的數據對象信息
    */
   private T data;

   public CommonResponse(Integer code, String message) {
       this.code = code;
       this.message = message;
   }

   public CommonResponse(T data) {
       this.data = data;
   }
}
  1. 在advice包中實現對響應的統一攔截com.sxzhongf.ad.common.advice.CommonResponseDataAdvice,參考 ResponseBodyAdvice, RestControllerAdvice 可查看源碼org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice
   @RestControllerAdvice
   public class CommonResponseDataAdvice implements ResponseBodyAdvice<Object> {
   
       /**
        * 判斷是否需要對響應進行處理
        *
        * @return false -> 不處理,true -> 處理
        */
       @Override
       public boolean supports(MethodParameter methodParameter, Class<? extends HttpMessageConverter<?>> converterType) {
   //
   //        //獲取當前處理請求的controller的方法
   //        String methodName = methodParameter.getMethod().getName().toLowerCase();
   //        // 不攔截/不需要處理返回值 的方法
   //        String method = "login"; //如登錄
   //        //不攔截
   //        return !method.equals(methodName);
   
           // 如果類上標記了@IgnoreResponseAdvice,則不攔截
           if (methodParameter.getDeclaringClass().isAnnotationPresent(IgnoreResponseAdvice.class)) {
               return false;
           }
   
           // 如果方法上標記了@IgnoreResponseAdvice,則不攔截
           if (methodParameter.getMethod().isAnnotationPresent(IgnoreResponseAdvice.class)) {
               return false;
           }
   
           //對響應進行處理,執行beforeBodyWrite方法
           return true;
       }
   
       /**
        * 目的 攔截CommonResponse
        *
        * @param body 原始的Controller需要返回的數據
        */
       @Override
       public Object beforeBodyWrite(Object body, MethodParameter returnType,
                                     MediaType selectedContentType,
                                     Class<? extends HttpMessageConverter<?>> selectedConverterType,
                                     ServerHttpRequest request,
                                     ServerHttpResponse response) {
   
           CommonResponse<Object> commonResponse = new CommonResponse<>();
   
           if (null == body) {
               return commonResponse;
           } else if (body instanceof CommonResponse) {
               commonResponse = (CommonResponse<Object>) body;
           } else {
               commonResponse.setData(body);
           }
           return commonResponse;
       }
   }

我們在annotation包下麵添加一個註解com.sxzhongf.ad.common.annotation.IgnoreResponseAdvice,用它來標柱是否需要支持上面的統一返回攔截。

   /**
    * IgnoreResponseAdvice for 標示需要忽略攔截動作
    *
    * @author <a href="mailto:[email protected]">Isaac.Zhang</a>
    */
   //ElementType.TYPE 表示該註解可用於class
   //ElementType.METHOD 表示可用於方法
   @Target({ElementType.TYPE, ElementType.METHOD})
   @Retention(RetentionPolicy.RUNTIME)
   public @interface IgnoreResponseAdvice {
   }
通用異常處理

異常處理也是統一的,那麼同樣就要使用到RestControllerAdvice,同時,需要使用的Spring 的ExceptionHandler進行異常處理

  1. 創建統一異常攔截類
/**
 * GlobalExceptionAdvice for 全局統一異常攔截
 *
 * @author <a href="mailto:[email protected]">Isaac.Zhang</a>
 * @see RestControllerAdvice
 * @see ExceptionHandler
 */
@RestControllerAdvice
public class GlobalExceptionAdvice {

    /**
     * 對 {@link AdException} 進行統一處理
     * {@link ExceptionHandler}  對指定的異常進行攔截
     * 可優化:
     * 定義多種類異常,實現對應的異常處理,
     * 例如:
     * <ul>
     * <li>
     * 推廣單元操作異常,拋出 AdUnitException
     * </li>
     * <li>
     * Binlog 解析異常,拋出 BinlogException
     * </li>
     * </ul>
     * 攔截Spring Exception 使用 {@link ExceptionHandler}註解
     */
    @ExceptionHandler(value = AdException.class)
    public CommonResponse<String> handlerAdException(HttpServletRequest request, AdException ex) {
        CommonResponse<String> response = new CommonResponse<>(-1, "business error");
        response.setData(ex.getMessage());
        return response;
    }
}
  1. 創建通用異常類
/**
 * AdException for 統一異常處理類
 *
 * @author <a href="mailto:[email protected]">Isaac.Zhang</a>
 */
public class AdException extends Exception {
    public AdException(String message) {
        super(message);
    }
}
通用配置信息

通過HTTP消息轉換器HttpMessageConverter,實現對象轉換,Java Object -> HTTP 數據流

  1. 新增WebConfiguration,我們通過實現org.springframework.web.servlet.config.annotation.WebMvcConfigurer來定製和修改Spring MVC的配置信息。
/**
 * WebConfiguration for 對Spring的配置和行為進行定製修改
 *
 * @author <a href="mailto:[email protected]">Isaac.Zhang</a>
 * @see WebMvcConfigurer
 */
@Configuration
public class WebConfiguration implements WebMvcConfigurer {
    /**
     * 匹配路由請求規則
     */
    @Override
    public void configurePathMatch(PathMatchConfigurer configurer) {

    }
    /**
     * 註冊自定義的Formatter 和 Convert
     */
    @Override
    public void addFormatters(FormatterRegistry registry) {

    }
    /**
     * 添加靜態資源處理器
     */
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {

    }
    /**
     * 添加自定義視圖控制器
     */
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {

    }
    /**
     * 添加自定義方法參數處理器
     */
    @Override
    public void addArgumentResolvers(List<HandlerMethodArgumentResolver> resolvers) {

    }
    /**
     * 配置消息轉換器
     */
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        //清空所有轉換器
        converters.clear();
        // Java Obj -> Json Obj (http header: application/json)
        converters.add(new MappingJackson2HttpMessageConverter());
    }
}

做一個好人。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 午休後,看看電視,在回顧下新的知識 函數。相信很多小伙伴在學習python後 ,學到函數就會有一部分人放棄了,從努力到放棄(內容過於真實) 好希望我也能有很多粉絲,hhh.... 函數: 什麼是函數?作用是什麼呢? 函數就是讓我們來偷懶的,沒錯,就是這樣簡單粗暴的解釋。。。 作用呢?就是我們定義的函 ...
  • 1.變數的輸入: input函數: input() input("請輸入銀行卡密碼") password = input("請輸入銀行卡密碼") 變數名 = input("XXX") # 用輸入函數給變數賦值 輸入函數給變數賦值舉例: 註:所有input()得到的數據類型都是str字元串類型 2.變 ...
  • 輸出函數是最常用的,對print()參數的準確認識尤為重要。 sep='':sep參數表示函數中不同value的分隔符,預設為一個空格。 end='':end參數表示函數結尾的處理,預設換行。 例如: ...
  • Swing的輸入框仍然分成兩類:單行輸入框和多行輸入框,但與AWT的同類控制項相比,它們在若幹細節上有所調整。首先說單行輸入框,AWT的單行輸入框名叫TextField,平時輸入什麼字元它便顯示什麼字元,可一旦調用了setEchoChar方法設置回顯字元,TextField馬上變成只顯示密文字元了。然 ...
  • 在使用Visual C++ 6.0打開文件時可能會出現下麵的情況 這可能是Vc6.0和win7相容性問題。 方法: 下載filetool即可 鏈接:https://pan.baidu.com/s/1Xmx0XI0Dy9uZGJEQW4cHQg 提取碼:drgz 下載之後,解壓到一個目錄,我這個是解壓 ...
  • 關於python單例模式是什麼,以及一些實現方法的整理與講解。 ...
  • 今天在刷題的時候用到了正則,用的過程中就感覺有點不太熟練了,很久沒有用正則都有點忘了。所以現在呢,我們就一起來review一下python中正則模塊re的用法吧。 今天是review,所以一些基礎的概念就不做介紹了,先來看正則中的修飾符以及它的功能: 修飾符 re.I 使匹配對大小寫不敏感 re.L ...
  • 題目 "The XOR Largest Pair" 解析 一年前聽學長講這道題,什麼01trie,好高級啊,所以沒學,現在一看。。。。 看到xor就應該想到二進位,一看數據$A_i using namespace std; const int N = 4e6 + 10; int n, a, num, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...