springboot全局异常处理简单入门

如果不加异常处理
会出现一堆代码,一点也不友好

"timestamp": "2020-03-19T01:31:15.241+0000",
    "status": 500,
    "error": "Internal Server Error",
    "message": "页码值无效",
    "trace": "java.lang.IllegalArgumentException: 页码值无效\r\n\tat org.springframework.util.Assert.isTrue(Assert.java:118)\r\n\tat com.cy.pj.sys.service.impl.SysLogServiceImpl.findPageObjects(SysLogServiceImpl.java:37)\r\n\tat com.cy.pj.sys.controller.SysLogController.doFindObjects(SysLogController.java:33)\r\n\tat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)\r\n\tat sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)\r\n\tat sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)\r\n\tat java.lang.reflect.Method.invoke(Method.java:498)\r\n\tat org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:190)\r\n\tat org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:138)\r\n\tat org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:106)\r\n\tat org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:879)\r\n\tat org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:793)\r\n\tat 

解决方法之一 —— 在Controller层写一个异常处理方法

/**
     * 描述的方法为一个异常处理方法
     * @param e
     * @return
     */
    @ExceptionHandler(RuntimeException.class)
    public JsonResult doHandleRuntimeException(RuntimeException e){
        e.printStackTrace();
        return new JsonResult(e);
    }

但是考虑代码复用,首先想到继承,似乎也不好,那么用springboot的@ControllerAdvice

/**
 * 统一异常处理类的定义
 * @ControllerAdvice描述的类是全局异常处理类
 * @author DELL
 */
@ControllerAdvice
public class GlobalExceptionHandler {
    /** JDK中的自带的日志API */
    @ExceptionHandler(RuntimeException.class)
    @ResponseBody
    public JsonResult doHandleRuntimeException(RuntimeException e){
        e.printStackTrace();
        return new JsonResult(e);
    }
}

打印结果

{
    "state": 0,
    "message": "页码值无效",
    "data": null
}

JsonResult

/**
 * 封装控制层方法的返回结果
 * @author DELL
 */
@Data
@NoArgsConstructor
public class JsonResult implements Serializable {

    /**状态码  1表示SUCCESS,0表示ERROR*/
    private int state=1;
    /**状态信息*/
    private String message="ok";
    /**正确数据*/
    private Object data;

    public JsonResult(String message){
        this.message=message;
    }
    /**一般查询时调用,封装查询结果*/
    public JsonResult(Object data) {
        this.data=data;
    }
    /**出现异常时时调用*/
    public JsonResult(Throwable t){
        this.state=0;
        this.message=t.getMessage();
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值