zoukankan      html  css  js  c++  java
  • 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 转载请注明出处, 谢谢

  • 相关阅读:
    lodash-es 最小化引入
    shortid id生成器
    结构体声明的方式 及类namespace的前置声明
    结构体中使用 箭头 与 点 的区别
    进入Docker容器的几种方式
    协议分析处理工具ProtoBuf
    PubSub ——“发布/订阅”模式
    在Windows/linux下进行gdb调试
    C++中的域作用符::的作用
    C++ 中常用关键字及其用法
  • 原文地址:https://www.cnblogs.com/wenbronk/p/6850785.html
Copyright © 2011-2022 走看看