• springboot-20-全局异常处理


    springboot的全局异常处理

    1. 新建一个类GlobalDefaultExceptionHandler
    在class上注解  @ControllerAdvice
    
    方法上注解 @ExceptionHandler(value=Exception.class)

    这样程序出错, 就会返回默认配置的信息了

    package com.iwhere.scrapy.exception;
    
    import javax.servlet.http.HttpServletRequest;
    
    import org.apache.commons.lang3.ArrayUtils;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.web.bind.annotation.ControllerAdvice;
    import org.springframework.web.bind.annotation.ExceptionHandler;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    import com.iwhere.scrapy.enums.PublicRespEnum;
    import com.iwhere.scrapy.model.ResponseModel;
    
    @ControllerAdvice
    public class GlobalExceptionHandler {
        private static final Logger LOGGER = LoggerFactory.getLogger(GlobalExceptionHandler.class);
    
        @ExceptionHandler(Exception.class)
        @ResponseBody
        public ResponseModel defaultHandler(HttpServletRequest request, Exception exception) {
            StringBuffer url = request.getRequestURL();
            String params = request.getQueryString();
            // 发生地点
            int lineNum = 0;
            String className = null;
            String methodName = null;
            StackTraceElement[] st = exception.getStackTrace();
            if (ArrayUtils.isNotEmpty(st)) {
                lineNum = st[0].getLineNumber();
                className = st[0].getClassName();
                methodName = st[0].getMethodName();
            }
    
            String message = exception.getMessage();
            LOGGER.info("Exception: {}#{}() 在第{}行发生{}异常!!! url: {}, params: {}, info: {}", className, methodName, lineNum,
                    exception.getClass().getName(), url, params, message);
            
            return ResponseModel.getModel(PublicRespEnum.RESCODE_500, message);
        }
    
    }

    其中ResponseModel 是一个统一返回模型

    原创地址: http://www.cnblogs.com/wenbronk/p/6850785.html 转载请注明出处, 谢谢

  • 相关阅读:
    java.util.logging.Logger使用详解
    JAVA7新增的对自动关闭资源的try语句的问题
    java的"1"+"asd"的底层
    oracle的存储过程与函数
    java.exe和javaw.exe有什么区别?
    需要看的知识点
    关于String-StringBuffer-Stringbuilder的知识点
    tomcat是什么?
    生产系统总结
    less
  • 原文地址:https://www.cnblogs.com/wenbronk/p/6850785.html
Copyright © 2020-2023  润新知