Spring?Cloud?通過?Gateway?webflux實現(xiàn)網(wǎng)關(guān)異常處理
一、webflux 編程實現(xiàn)網(wǎng)關(guān)異常處理
我們知道在某一個服務(wù)中出現(xiàn)異常,可以通過 @ControllerAdvice + @ExceptionHandler 來統(tǒng)一異常處理,即使是在微服務(wù)架構(gòu)中,我們也可以將上述統(tǒng)一異常處理放入到公共的微服務(wù)中,這樣哪一個微服務(wù)需要,直接引入模塊即可。 但是如果我們的 網(wǎng)關(guān)微服務(wù) 出現(xiàn)了異常,該怎么處理呢?
步驟如下:
- 在網(wǎng)關(guān)微服務(wù)中創(chuàng)建一個類,添加 @Configuration 注解將其作為配置類.
- 實現(xiàn)自定義 ErrorWebExceptionHandler 接口,重寫 handle 方法.
- 在 handle 方法中實現(xiàn)統(tǒng)一異常處理.
代碼注釋如下:
@Slf4j @Configuration public class GlobalExceptionConfig implements ErrorWebExceptionHandler { @Autowired private ObjectMapper objectMapper; /** * 全局異常處理 * @param exchange 交換器(request, response) * @param ex 出現(xiàn)異常時的異常對象 * @return */ @Override public Mono<Void> handle(ServerWebExchange exchange, Throwable ex) { Map<String, String> result = new HashMap<>(); //1.獲取響應(yīng)對象 ServerHttpResponse response = exchange.getResponse(); //2. response 是否結(jié)束(一般不用,可以用來處理多個異常的場景) if(response.isCommitted()) { return Mono.error(ex); } //3.設(shè)置響應(yīng)頭類型(JSON) response.getHeaders().setContentType(MediaType.APPLICATION_JSON); //4.設(shè)置響應(yīng)狀態(tài)碼 if (ex instanceof IllegalTokenException) { //是我們自定義的異常 response.setStatusCode(HttpStatus.FORBIDDEN); } else { //不是我們自定義的異常,就通過 "服務(wù)器異常" 來處理 response.setStatusCode(HttpStatus.INTERNAL_SERVER_ERROR); } //5.處理統(tǒng)一異常響應(yīng) return response.writeWith(Mono.fromSupplier(() -> { DataBufferFactory bufferFactory = response.bufferFactory(); result.put("msg", ex.getMessage()); try { return bufferFactory.wrap(objectMapper.writeValueAsBytes(result)); } catch (JsonProcessingException e) { throw new RuntimeException(e); } })); } }
IllegalTokenException:是我們自定義的異常,通常在上述代碼的第四步中,就需要根據(jù)我們判斷 ex 屬于我們的哪種自定義異常,然后進(jìn)行對應(yīng)的狀態(tài)碼處理.
Mono.fromSupplier():是一個函數(shù)式接口,參數(shù)這里通過一 lamada 表達(dá)式實現(xiàn)(無參,返回值是一個 Mono)泛型. 這里要實現(xiàn)的邏輯就是把異常的響應(yīng)進(jìn)行封裝.bufferFactory.wrap:這里就是按照 webflux 編程的方式,參數(shù)是 json 格式(通過 ObjectMapper 轉(zhuǎn)化),得到一個 Mono 對象.
那么,如果在網(wǎng)關(guān)的中拋出了異常,如下:
到此這篇關(guān)于Spring Cloud - 通過 Gateway webflux 編程實現(xiàn)網(wǎng)關(guān)異常處理的文章就介紹到這了,更多相關(guān)Spring Cloud Gateway網(wǎng)關(guān)異常內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Boot存在路徑遍歷漏洞CVE-2021-22118的問題解析
CVE-2021-22118?是一個在?Spring?Boot?中發(fā)現(xiàn)的漏洞,該漏洞關(guān)系到?Spring?Boot?的開發(fā)者工具(Devtools)中的遠(yuǎn)程更新(Remote?Update)功能,這篇文章主要介紹了Spring?Boot存在路徑遍歷漏洞CVE-2021-22118,需要的朋友可以參考下2023-09-09