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

