Spring-全域性異常攔截

三刀刀刀刀刀發表於2018-12-18

Spring MVC那一篇裡提到了異常攔截來做引數校驗返回,那裡是對特定的 controller 做異常捕捉,但是我們也可以選擇全域性攔截處理

快速開始

@ResponseBody
@ControllerAdvice
public class ExceptionAdvice {
    private static Logger logger = LoggerFactory.getLogger(ExceptionAdvice.class);

    /***
    * 引數繫結異常
    * @date 2018/10/16
    * @param exception HttpMessageNotReadableException
    */
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler(HttpMessageNotReadableException.class)
    public Result<Long> messageNotReadable(HttpMessageNotReadableException exception){
        InvalidFormatException formatException = (InvalidFormatException)exception.getCause();
        List<JsonMappingException.Reference> e = formatException.getPath();
        String fieldName = "";
        for (JsonMappingException.Reference reference :e){
            String fieldName = reference.getFieldName();
        }
        logger.error("引數不匹配"+exception);
        return Result.createFailResult(fieldName+"引數型別不匹配");
    }

    /***
    * 全域性異常,如果沒有匹配到上述準確的異常,都會到這裡來處理
    * @date 2018/10/16
    * @param e 沒有匹配到的全域性異常
    */
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler(Exception.class)
    public Result<String> all(Exception e){
        //這裡的log使用了“,”,這樣能把異常的堆疊資訊全部列印出來,更容易定位bug
        logger.error("異常:",e);
        return Result.createFailResult("工程搶救中……請稍後再試");
    }
}

@ControllerAdvice

@ControllerAdvice 預設監控所有的 @RequestMapping 方法,也可以對指定過濾的條件:

// 監控所有的被@RestController註解的Controllers類 
@ControllerAdvice(annotations = RestController.class)

// 監控特定的包下的Controllers類
@ControllerAdvice("org.example.controllers")

// 監控指定類的Controllers類
@ControllerAdvice(assignableTypes = {ControllerInterface.class, AbstractController.class})

相關文章