国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【微服務網(wǎng)關(guān)---Gateway 的全局異常處理器】

這篇具有很好參考價值的文章主要介紹了【微服務網(wǎng)關(guān)---Gateway 的全局異常處理器】。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

前言

Gateway網(wǎng)關(guān)統(tǒng)一全局異常處理操作 方便前端看到 這里要精細化翻譯,默認返回用戶是看不懂的 所以需要配置一個 Gateway 的全局異常處理器


如果沒有網(wǎng)關(guān)全局異常的 會如下截圖
gateway全局異常處理,微服務,分布式,微服務,gateway,spring

一、使用步驟

1.編寫 GlobalExceptionHandler

代碼如下:

package cn.cws.framework.gatewayservice.handler;

import cn.cws.framework.core.common.service.ApiResult;
import cn.cws.framework.gatewayservice.handler.code.GatewayErrorCode;
import cn.cws.framework.gatewayservice.util.WebFrameworkUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.web.reactive.error.ErrorWebExceptionHandler;
import org.springframework.core.annotation.Order;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.http.server.reactive.ServerHttpResponse;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.server.ResponseStatusException;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

/**
 * Gateway 的全局異常處理器,將 Exception 翻譯成 ApiResult + 對應的異常編號
 *
 * 在功能上,和 核心 的 GlobalExceptionHandler 類是一致的
 *
 * @author zw
 */
@Component
@Order(-1) // 保證優(yōu)先級高于默認的 Spring Cloud Gateway 的 ErrorWebExceptionHandler 實現(xiàn)
@Slf4j
public class GlobalExceptionHandler implements ErrorWebExceptionHandler {

    @Override
    public Mono<Void> handle(ServerWebExchange exchange, Throwable ex) {
        // 已經(jīng) commit,則直接返回異常
        ServerHttpResponse response = exchange.getResponse();
        if (response.isCommitted()) {
            return Mono.error(ex);
        }

        // 轉(zhuǎn)換成 CommonResult
        ApiResult<?> result;
        if (ex instanceof ResponseStatusException) {
            result = responseStatusExceptionHandler(exchange, (ResponseStatusException) ex);
        } else {
            result = defaultExceptionHandler(exchange, ex);
        }

        // 返回給前端
        return WebFrameworkUtils.writeJSON(exchange, result);
    }

    /**
     * 處理 Spring Cloud Gateway 默認拋出的 ResponseStatusException 異常
     */
    private  ApiResult<?> responseStatusExceptionHandler(ServerWebExchange exchange,
                                                           ResponseStatusException ex) {
        // TODO zw 這里要精細化翻譯,默認返回用戶是看不懂的
        ServerHttpRequest request = exchange.getRequest();
        log.error("[responseStatusExceptionHandler][uri({}/{}) 發(fā)生異常]", request.getURI(), request.getMethod(), ex);
        if (ex.getRawStatusCode()== GatewayErrorCode.SYS_GATEWAY_ERROR_NACOS.getCode()){
            return ApiResult.buildFail(ex.getRawStatusCode(), " 請聯(lián)系管理人員 : "+ex.getReason()+GatewayErrorCode
                    .SYS_GATEWAY_ERROR_NACOS.getMsg());
        }
        return ApiResult.buildFail(ex.getRawStatusCode(), ex.getReason());
        // return ApiResult.buildFail(ex.getRawStatusCode(), ex.getReason());
    }

    /**
     * 處理系統(tǒng)異常,兜底處理所有的一切
     */
    @ExceptionHandler(value = Exception.class)
    public  ApiResult<?> defaultExceptionHandler(ServerWebExchange exchange,
                                                Throwable ex) {
        ServerHttpRequest request = exchange.getRequest();
        log.error("[defaultExceptionHandler][uri({}/{}) 發(fā)生異常]", request.getURI(), request.getMethod(), ex);
        //  TODO zw 是否要插入異常日志呢?
        // 返回 ERROR CommonResult
        log.error("[responseStatusExceptionHandler][uri({}/{}) 發(fā)生異常]", request.getURI(), request.getMethod(), ex);
        return ApiResult.buildFail(-1, ex.getMessage());
       // return ApiResult.buildFail(-1,ex.getStackTrace().toString());
    }

}

2.WebFrameworkUtils 工具類

代碼如下:

package cn.cws.framework.gatewayservice.util;

import cn.cws.framework.core.common.util.JsonKit;
import lombok.extern.slf4j.Slf4j;
import org.springframework.cloud.gateway.route.Route;
import org.springframework.cloud.gateway.support.ServerWebExchangeUtils;
import org.springframework.core.io.buffer.DataBufferFactory;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.http.server.reactive.ServerHttpResponse;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

/**
 * Web 工具類
 *
 *
 * @author zw
 */
@Slf4j
public class WebFrameworkUtils {

    private static final String HEADER_TENANT_ID = "tenant-id";




    private WebFrameworkUtils() {}

    /**
     * 將 Gateway 請求中的 header,設置到 HttpHeaders 中
     *
     * @param tenantId 租戶編號
     * @param httpHeaders WebClient 的請求
     */
    public static void setTenantIdHeader(Long tenantId, HttpHeaders httpHeaders) {
        if (tenantId == null) {
            return;
        }
        httpHeaders.set(HEADER_TENANT_ID, String.valueOf(tenantId));
    }

    public static Long getTenantId(ServerWebExchange exchange) {
        String tenantId = exchange.getRequest().getHeaders().getFirst(HEADER_TENANT_ID);
        return tenantId != null ? Long.parseLong(tenantId) : null;
    }

    /**
     * 返回 JSON 字符串
     *
     * @param exchange 響應
     * @param object 對象,會序列化成 JSON 字符串
     */
    @SuppressWarnings("deprecation") // 必須使用 APPLICATION_JSON_UTF8_VALUE,否則會亂碼
    public static Mono<Void> writeJSON(ServerWebExchange exchange, Object object) {
        // 設置 header
        ServerHttpResponse response = exchange.getResponse();
        response.getHeaders().setContentType(MediaType.APPLICATION_JSON_UTF8);
        // 設置 body
        return response.writeWith(Mono.fromSupplier(() -> {
            DataBufferFactory bufferFactory = response.bufferFactory();
            try {

                return bufferFactory.wrap(JsonKit.toJsonByte(object));
            } catch (Exception ex) {
                ServerHttpRequest request = exchange.getRequest();
                log.error("[writeJSON][uri({}/{}) 發(fā)生異常]", request.getURI(), request.getMethod(), ex);
                return bufferFactory.wrap(new byte[0]);
            }
        }));
    }

    /**
     * 獲得請求匹配的 Route 路由
     *
     * @param exchange 請求
     * @return 路由
     */
    public static Route getGatewayRoute(ServerWebExchange exchange) {
        return exchange.getAttribute(ServerWebExchangeUtils.GATEWAY_ROUTE_ATTR);
    }

}

3.json 工具類

代碼如下:

package cn.cws.framework.core.common.util;

import com.fasterxml.jackson.annotation.JsonFilter;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.*;
import com.fasterxml.jackson.databind.ser.FilterProvider;
import com.fasterxml.jackson.databind.ser.impl.SimpleBeanPropertyFilter;
import com.fasterxml.jackson.databind.ser.impl.SimpleFilterProvider;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import lombok.SneakyThrows;

import java.io.IOException;
import java.io.StringWriter;
import java.util.List;
import java.util.Map;

/**
 * @author zw
 */
public class JsonKit {
    public static final ObjectMapper OBJECT_MAPPER = createObjectMapper();
    private static final ObjectMapper IGNORE_OBJECT_MAPPER = createIgnoreObjectMapper();

    private static ObjectMapper createIgnoreObjectMapper() {
        ObjectMapper objectMapper = createObjectMapper();
        objectMapper.addMixIn(Object.class, DynamicMixIn.class);
        return objectMapper;
    }

    /**
     * 初始化ObjectMapper
     */
    public static ObjectMapper createObjectMapper() {
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true);
        objectMapper.configure(DeserializationFeature.ACCEPT_EMPTY_STRING_AS_NULL_OBJECT, true);
        objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
        objectMapper.configure(DeserializationFeature.USE_BIG_DECIMAL_FOR_FLOATS, true);
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
        objectMapper.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);
        objectMapper.registerModule(new JavaTimeModule());
        return objectMapper;
    }

    public static String object2Json(Object o) {
        StringWriter sw = new StringWriter();
        JsonGenerator gen = null;
        try {
            gen = new JsonFactory().createGenerator(sw);
            OBJECT_MAPPER.writeValue(gen, o);
        } catch (IOException e) {
            throw new RuntimeException("不能序列化對象為Json", e);
        } finally {
            if (null != gen) {
                try {
                    gen.close();
                } catch (IOException e) {
                    throw new RuntimeException("不能序列化對象為Json", e);
                }
            }
        }
        return sw.toString();
    }


    @SneakyThrows
    public static byte[] toJsonByte(Object object) {
        return OBJECT_MAPPER.writeValueAsBytes(object);
    }

    @SneakyThrows
    public static String toJsonString(Object object) {
        return OBJECT_MAPPER.writeValueAsString(object);
    }



    /**
     * @param ignoreFiledNames 要忽略的屬性名
     */
    public static String object2Json(Object o, String... ignoreFiledNames) {
        try {
            SimpleBeanPropertyFilter theFilter = SimpleBeanPropertyFilter.serializeAllExcept(ignoreFiledNames);
            FilterProvider filters = new SimpleFilterProvider().addFilter("dynamicFilter", theFilter);
            return IGNORE_OBJECT_MAPPER.writer(filters).writeValueAsString(o);
        } catch (IOException e) {
            throw new RuntimeException("不能序列化對象為Json", e);
        }
    }

    @JsonFilter("dynamicFilter")
    private static class DynamicMixIn {

    }

    public static Map<String, Object> object2Map(Object o) {
        return OBJECT_MAPPER.convertValue(o, Map.class);
    }


    /**
     * 將 json 字段串轉(zhuǎn)換為 對象.
     *
     * @param json  字符串
     * @param clazz 需要轉(zhuǎn)換為的類
     */
    public static <T> T json2Object(String json, Class<T> clazz) {
        try {
            return OBJECT_MAPPER.readValue(json, clazz);
        } catch (IOException e) {
            throw new RuntimeException("將 Json 轉(zhuǎn)換為對象時異常,數(shù)據(jù)是:" + json, e);
        }
    }

    /**
     * 將 json 字段串轉(zhuǎn)換為 List.
     */
    public static <T> List<T> json2List(String json, Class<T> clazz) {
        JavaType type = OBJECT_MAPPER.getTypeFactory().constructCollectionType(List.class, clazz);
        try {
            return OBJECT_MAPPER.readValue(json, type);
        } catch (Exception e) {
            return null;
        }
    }


    /**
     * 將 json 字段串轉(zhuǎn)換為 數(shù)據(jù).
     */
    public static <T> T[] json2Array(String json, Class<T[]> clazz) throws IOException {
        return OBJECT_MAPPER.readValue(json, clazz);

    }

    public static <T> T node2Object(JsonNode jsonNode, Class<T> clazz) {
        try {
            T t = OBJECT_MAPPER.treeToValue(jsonNode, clazz);
            return t;
        } catch (JsonProcessingException e) {
            throw new RuntimeException("將 Json 轉(zhuǎn)換為對象時異常,數(shù)據(jù)是:" + jsonNode.toString(), e);
        }
    }

    public static JsonNode object2Node(Object o) {
        try {
            if (o == null) {
                return OBJECT_MAPPER.createObjectNode();
            } else {
                return OBJECT_MAPPER.convertValue(o, JsonNode.class);
            }
        } catch (Exception e) {
            throw new RuntimeException("不能序列化對象為Json", e);
        }
    }

    /**
     * JsonNode轉(zhuǎn)換為Java泛型對象,可以是各種類型。
     *
     * @param json String
     * @param tr   TypeReference,例如: new TypeReference< List<FamousUser> >(){}
     * @return List對象列表
     */
    public static <T> T json2GenericObject(String json, TypeReference<T> tr) {

        if (json == null || "".equals(json)) {
            throw new RuntimeException("將 Json 轉(zhuǎn)換為對象時異常,數(shù)據(jù)是:" + json);
        } else {
            try {
                return (T) OBJECT_MAPPER.readValue(json, tr);
            } catch (Exception e) {
                throw new RuntimeException("將 Json 轉(zhuǎn)換為對象時異常,數(shù)據(jù)是:" + json, e);
            }
        }
    }
}

4. 網(wǎng)關(guān)異常狀態(tài)碼

package cn.cws.framework.gatewayservice.handler.code;

import cn.cws.framework.core.common.constant.ModelEnum;

/**
 * @description: 網(wǎng)關(guān)異常狀態(tài)碼
 * @author:zw,微信:yingshengzw
 * @date: 2023/1/16
 * @Copyright: 公眾號:搬磚暗夜碼農(nóng) | 博客:https://itzhouwei.com - 沉淀、分享、成長,讓自己和他人都能有所收獲!
 */
@SuppressWarnings("all")
public enum GatewayErrorCode {


    SYS_GATEWAY_ERROR_NACOS(503," 服務沒有注冊到nacos上");



    private String msg;
    private int code;

    GatewayErrorCode(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public int getCode() {
        return code;
    }


    public void setCode(int code) {
        this.code = code;
    }

}

5. 測試結(jié)果如下

gateway全局異常處理,微服務,分布式,微服務,gateway,spring

總結(jié)

以上就是今天要講的內(nèi)容,本文僅僅簡單 所以需要配置一個 Gateway 的全局異常處理器文章來源地址http://www.zghlxwxcb.cn/news/detail-523487.html

到了這里,關(guān)于【微服務網(wǎng)關(guān)---Gateway 的全局異常處理器】的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務器費用

相關(guān)文章

  • SSM整合(三) | 異常處理器 - 項目異常的處理方案

    SSM整合(三) | 異常處理器 - 項目異常的處理方案

    異常處理器快速入門 程序開發(fā)過程中不可避免的會遇到異?,F(xiàn)象 出現(xiàn)異常現(xiàn)象的常見位置與常見原因如下 : 框架內(nèi)部拋出的異常:因使用不規(guī)范導致 數(shù)據(jù)層拋出的異常:因外部服務器故障導致(例如:服務器訪問超時) 業(yè)務層拋出的異常:因業(yè)務邏輯書寫錯誤導致(例如

    2024年02月02日
    瀏覽(20)
  • Spring異常處理器

    Spring異常處理器

    ?問題: ? 程序允許不免的在各層都可能會產(chǎn)生異常,我們該如何處理這些異常? 如果只是在方法里面單獨使用 try… catch… 語句去一個一個的進行捕捉處理的話,那毫無疑問是不現(xiàn)實的,因為異常數(shù)量是非常龐大的并且對于異常的出現(xiàn)種類是不可預料的,于是我們可以使用

    2024年02月13日
    瀏覽(19)
  • SpringMVC之異常處理器

    SpringMVC提供了一個處理控制器方法執(zhí)行過程中所出現(xiàn)的異常的接口:HandlerExceptionResolver。 HandlerExceptionResolver接口的實現(xiàn)類有:DefaultHandlerExceptionResolver(默認的)和 SimpleMappingExceptionResolver(自定義的)。 這里配置了兩個異常,出現(xiàn)其中一個異常后跳轉(zhuǎn)到error頁面。 以上就是異

    2024年02月10日
    瀏覽(24)
  • 13、SpringMVC之異常處理器

    13、SpringMVC之異常處理器

    創(chuàng)建名為spring_mvc_exception的新module,過程參考9.1節(jié)和9.5節(jié) SpringMVC 提供了一個處理控制器方法執(zhí)行異常的接口:HandlerExceptionResolver HandlerExceptionResolver 接口的實現(xiàn)類有:DefaultHandlerExceptionResolver 和 SimpleMappingExceptionResolver 實際工作中,有時使用 SimpleMappingExceptionResolver 異常解析器

    2024年02月05日
    瀏覽(25)
  • Spring MVC 異常處理器

    Spring MVC 異常處理器

    如果不加以異常處理,錯誤信息肯定會拋在瀏覽器頁面上,這樣很不友好,所以必須進行異常處理。 系統(tǒng)的dao、service、controller出現(xiàn)都通過throws Exception向上拋出,最后由springmvc前端控制器交由異常處理器進行異常處理,如下圖: 編寫controller 在index.jsp里面定義超鏈接

    2024年01月22日
    瀏覽(28)
  • SpringMVC的攔截器和異常處理器

    目錄 lerInterceptor 攔截器 1、攔截器的作用 2、攔截器的創(chuàng)建 3、攔截器的三個抽象方法 4、攔截器的配置 5、多個攔截器的執(zhí)行順序 SpringMVC的異常處理器 1、異常處理器概述 2、基于配置文件的異常處理 3、基于注解的異常處理 攔截器的作用時機 SpringMVC的攔截器作用于? 控制器

    2024年02月02日
    瀏覽(40)
  • SpringMVC之攔截器和異常處理器

    學習的最大理由是想擺脫平庸,早一天就多一份人生的精彩;遲一天就多一天平庸的困擾。各位小伙伴,如果您: 想系統(tǒng)/深入學習某技術(shù)知識點… 一個人摸索學習很難堅持,想組團高效學習… 想寫博客但無從下手,急需寫作干貨注入能量… 熱愛寫作,愿意讓自己成為更好

    2024年02月03日
    瀏覽(20)
  • Spring Boot 如何自定義異常處理器

    Spring Boot 如何自定義異常處理器

    在Spring Boot應用程序中,異常處理是一個非常重要的方面。如果您不處理異常,應用程序可能會崩潰或出現(xiàn)不可預料的行為。默認情況下,Spring Boot將未捕獲的異常返回給客戶端。這通常不是期望的行為,因為客戶端可能無法理解異常信息。在本文中,我們將介紹如何在Sprin

    2024年02月06日
    瀏覽(21)
  • [ARM 匯編]進階篇—異常處理與中斷—2.4.2 ARM處理器的異常向量表

    [ARM 匯編]進階篇—異常處理與中斷—2.4.2 ARM處理器的異常向量表

    異常向量表簡介 在ARM架構(gòu)中,異常向量表是一組固定位置的內(nèi)存地址,它們包含了處理器在遇到異常時需要跳轉(zhuǎn)到的處理程序的入口地址。每個異常類型都有一個對應的向量地址。當異常發(fā)生時,處理器會自動跳轉(zhuǎn)到對應的向量地址,并開始執(zhí)行異常處理程序。 異常向量表

    2024年02月09日
    瀏覽(89)
  • SpringBoot | RestTemplate異常處理器ErrorHandler使用詳解

    SpringBoot | RestTemplate異常處理器ErrorHandler使用詳解

    關(guān)注wx:CodingTechWork ??在代碼開發(fā)過程中,發(fā)現(xiàn)很多地方通過 RestTemplate 調(diào)用了第三方接口,而第三方接口需要根據(jù)某些狀態(tài)碼或者異常進行重試調(diào)用,此時,要么在每個調(diào)用的地方進行異常捕獲,然后重試;要么在封裝的 RestTemplate 工具類中進行統(tǒng)一異常捕獲和封裝。當然

    2024年02月12日
    瀏覽(17)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包