@ControllerAdvice全局异常捕捉失效的问题

今天,刚了解下SpringBoot的@ControllerAdvice与@ExceptionHanlder搭配就能实现全局捕捉异常的问题,但是当我信心满满将进入如下操作后,却发现不仅全局异常捕捉没有生效,而且原来的控制方法也全部失效,之前的控制方法可以访问的页面也都404

@ControllerAdvice
public class testController {
    public class ExceptionHanlder {
        @ExceptionHandler(Exception.class)
        public String a(Exception e){
            Logger logger= LoggerFactory.getLogger(getClass());
            logger.error("出错了"+e.getMessage());
            return e.getMessage();
        }
    }
    @RequestMapping("/")
    public String hello(){
      return "index";
    }
    @RequestMapping("/a")
    public String index(){
        int b=10/0;
        Logger logger= LoggerFactory.getLogger(getClass());
        logger.error("出错了++++=");
        return "a";
    }/**/

这是怎么回事呢,后面经过自己多次尝试,才发现@ControllerAdvice注解的类里面不能再写非异常出来的控制器方法,像上图操作会导致控制方法失效,页面访问404。

而造成这个原因就是

  只有当捕获异常后,才会进行这个@ControllerAdvice控制器类,而我们的异常定义在标有@ControllerAdvice的类非异常处理的控制器方法中。这样会陷入一个逻辑死循环
   因为要先进入到控制器方法中,就得执行异常语句才能进入这个@ControllerAdvice的类,而执行异常语句的控制器方法的类又刚刚好是与全局异常类是同一个类。所以会造成要执行异常语句等先进入@ControllerAdvice的类,而要先进入@ControllerAdvice的类,就要先执行异常语句这样的逻辑死锁当中
   最后的结果就是所有页面跳转的控制器方法全部失效,页面访问404,全局异常捕捉也失去作用(因为根本就没异常)

   最后解决将非异常处理的控制方法与全局异常捕捉放在不同的类中,在用@Controller与@ControllerAdvice分别注解:

package com.example.testdevtools.Controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

@Controller
public class testController {
    @RequestMapping("/")
    public String hello(){
      return "index";
    }
    @RequestMapping("/a")
    public String index(){
        int b=10/0;
        Logger logger= LoggerFactory.getLogger(getClass());
        logger.error("出错了++++=");
        return "a";
    }/**/
}/**/
package com.example.testdevtools.ExceptionController;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;

@ControllerAdvice
public class ExceptionHanlder {
    @ExceptionHandler(Exception.class)
    public String a(Exception e){
        Logger logger= LoggerFactory.getLogger(getClass());
        logger.error("出错了"+e.getMessage());
        return e.getMessage();
    }
}

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果不想使用@ControllerAdvice注解,我们也可以通过实现HandlerExceptionResolver接口来实现全局异常处理。具体步骤如下: 1. 创建一个类,实现HandlerExceptionResolver接口。 2. 在类中实现resolveException方法,该方法会在全局异常发生时被执行。 3. 在resolveException方法中,我们可以根据不同的异常类型进行不同的处理,比如返回自定义错误信息或者跳转到指定页面。 4. 最后,我们需要将该类注册到Spring框架中,可以通过在配置文件中进行配置或者使用注解的方式进行注册。 以下是一个简单的示例: ```java public class GlobalExceptionHandler implements HandlerExceptionResolver { @Override public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { // 返回自定义错误信息 ModelAndView modelAndView = new ModelAndView(); modelAndView.addObject("errorMsg", "系统错误,请稍后重试!"); modelAndView.setViewName("error"); return modelAndView; } } ``` 在上述代码中,我们实现了HandlerExceptionResolver接口并重写了resolveException方法。在该方法中,我们将错误信息存入ModelAndView中,并将viewName设置为"error",表示跳转到error页面显示错误信息。 最后,我们需要将该类注册到Spring框架中。可以通过在配置文件中进行配置或者使用注解的方式进行注册。例如,在Spring配置文件中添加如下配置: ```xml <bean id="globalExceptionHandler" class="com.example.GlobalExceptionHandler"/> ``` 在上述配置中,我们将GlobalExceptionHandler类注册为Spring的一个bean,并使用该类处理全局异常

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜鸟code+

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值