91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-04-08 22:30:58 來源:網絡 閱讀:543 作者:zhangpan0614 欄目:編程語言

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

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

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

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

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

  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:magicianisaac@gmail.com">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:magicianisaac@gmail.com">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:magicianisaac@gmail.com">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:magicianisaac@gmail.com">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());
    }
}
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

滦平县| 汉源县| 博白县| 龙井市| 新昌县| 营口市| 文安县| 巩留县| 巫山县| 葫芦岛市| 辽阳市| 化州市| 寿宁县| 石景山区| 周口市| 高尔夫| 庄河市| 西充县| 岳池县| 白玉县| 民丰县| 乌审旗| 青田县| 文登市| 万源市| 西吉县| 雷山县| 滨州市| 宜兴市| 长治县| 多伦县| 牟定县| 金坛市| 香河县| 宜都市| 遂昌县| 洛隆县| 横峰县| 宕昌县| 卫辉市| 皮山县|