| package com.dy.common.webUtil; | 
|   | 
| import io.swagger.v3.oas.annotations.Hidden; | 
| import io.swagger.v3.oas.annotations.media.Content; | 
| import io.swagger.v3.oas.annotations.media.Schema; | 
| import io.swagger.v3.oas.annotations.responses.ApiResponse; | 
| import io.swagger.v3.oas.annotations.responses.ApiResponses; | 
| import io.swagger.v3.oas.annotations.tags.Tag; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.web.bind.annotation.ControllerAdvice; | 
| import org.springframework.web.bind.annotation.ExceptionHandler; | 
| import org.springframework.web.bind.annotation.ResponseBody; | 
|   | 
| /** | 
|  * 全局异常处理,处理在Controller中抛出的异常,在Controller之前(如Fileter)发生的错误或异常由GlErrorCtrl处理 | 
|  * 此类是基于拦截器和实现指定接口(GlExceptionHandler和GlExceptionHandlerImpl) | 
|  * 另一种实现方式是基于注解切面实现(GlExceptionAspect) | 
|  */ | 
| //此类Tag注解不起作用,即不会在swagger-ui中显示,但会在每个controler的方法返回信息中显示。 | 
| //每个controller的方法上都显示本异常API显示啰嗦,所以不启用本注解 | 
| @Hidden //在SpringDoc中隐藏本接口API | 
| @Tag(name = "全局异常处理", description = "处理在Controller中抛出的异常,在Controller之前(如Fileter)发生的错误或异常由GlErrorCtrl处理") | 
| //在每个controler的方法返回信息中显示下面配置信息。 | 
| @ApiResponses(@ApiResponse( | 
|         responseCode = ResultCodeMsg.RsCode.EXCEPTION_CODE, | 
|         description = "发生异常", | 
|         content = {@Content(mediaType = "application/json", schema = @Schema(implementation = BaseResponse.class))} | 
| )) | 
| @ControllerAdvice | 
| @ResponseBody | 
| @Slf4j | 
| public class GlExceptionHandler { | 
|   | 
|     @ExceptionHandler | 
|     public BaseResponse GlExceptionHandler(GlException e){ | 
|         log.error("捕获到GlException:{}", e.getMsg(), e); | 
|         return BaseResponseUtils.buildException(e.getMsg()); | 
|     } | 
|   | 
|     public BaseResponse exceptionHandler(Throwable t) { | 
|         log.error("捕获到异常:{}",t.getMessage(),t); | 
|         return BaseResponseUtils.buildException("在Controller中或后产生异常:" + t.getMessage()); | 
|     } | 
| } |