lj-zhgd-ht/bonus-gateway/src/main/java/com/bonus/gateway/handler/GatewayExceptionHandler.java

61 lines
1.8 KiB
Java
Raw Normal View History

2024-06-27 11:31:28 +08:00
package com.bonus.gateway.handler;
2024-06-27 18:07:44 +08:00
import org.springframework.beans.factory.annotation.Value;
2024-06-27 11:31:28 +08:00
import org.springframework.cloud.gateway.support.NotFoundException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.web.reactive.error.ErrorWebExceptionHandler;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.Order;
import org.springframework.http.server.reactive.ServerHttpResponse;
import org.springframework.web.server.ResponseStatusException;
import org.springframework.web.server.ServerWebExchange;
import com.bonus.common.core.utils.ServletUtils;
import reactor.core.publisher.Mono;
/**
* 网关统一异常处理
*
* @author bonus
*/
@Order(-1)
@Configuration
public class GatewayExceptionHandler implements ErrorWebExceptionHandler
{
2024-06-27 18:07:44 +08:00
@Value("${system.jie-enable}")
public boolean jaData;
2024-06-27 11:31:28 +08:00
private static final Logger log = LoggerFactory.getLogger(GatewayExceptionHandler.class);
@Override
public Mono<Void> handle(ServerWebExchange exchange, Throwable ex)
{
ServerHttpResponse response = exchange.getResponse();
if (exchange.getResponse().isCommitted())
{
return Mono.error(ex);
}
String msg;
if (ex instanceof NotFoundException)
{
msg = "服务未找到";
}
else if (ex instanceof ResponseStatusException)
{
ResponseStatusException responseStatusException = (ResponseStatusException) ex;
msg = responseStatusException.getMessage();
}
else
{
msg = "内部服务器错误";
}
log.error("[网关异常处理]请求路径:{},异常信息:{}", exchange.getRequest().getPath(), ex.getMessage());
2024-06-27 18:07:44 +08:00
return ServletUtils.webFluxResponseWriter(response, msg,jaData);
2024-06-27 11:31:28 +08:00
}
}