当前位置: 首页 > news >正文

workerman 做网站廊坊快速优化排名

workerman 做网站,廊坊快速优化排名,装修设计网站哪个平台最好,汽车网站建设流程springmvc异常处理 spring中有三种方式可以优雅的处理异常 使用ExceptionHandler 使用HandlerExceptionResolver 使用ControllerAdviceExceptionHandler 使用ExceptionHandler 该方式只在指定的Controller有效,不会对其他的Controller产生影响 ControllerRequestMap…

springmvc异常处理

spring中有三种方式可以优雅的处理异常

  • 使用@ExceptionHandler
  • 使用HandlerExceptionResolver
  • 使用@ControllerAdvice+@ExceptionHandler

使用@ExceptionHandler

该方式只在指定的@Controller有效,不会对其他的@Controller产生影响

@Controller
@RequestMapping("/exception")
public class ExceptionController {

    // 使用@ExceptionHandler只对该@Controller有效,对其他Controller无效,如果想要对所有Controller生效,
    // 需要将该方法写到基类,让所有的Controller都继承该基类Controller
    @ExceptionHandler(BusinessException.class)
    @ResponseBody
    public String exception(Exception e)
{
        return "出现异常"+e.getMessage();
    }

    @RequestMapping("/testException")
    @ResponseBody
    public String testException(){
        User user = null;
        System.out.println(user.getId());
        return "success";
    }

    @RequestMapping("/testBusinessException")
    @ResponseBody
    public String testBusinessException(){
        throw new BusinessException();
    }
}

此时如果访问/exception/testBusinessException出现异常,就会跳转到exception方法中,将结果返回给浏览器

由于该方式只对@ExceptionHandler注解指定方法所在的Controller中生效,所以为了可以针对多个Controller生效,需要将@ExceptionHandler注解指定方法抽离到一个Controller基类中

@Controller
public class BaseController {
    @ExceptionHandler(BusinessException.class)
    @ResponseBody
    public String exception(Exception e)
{
        return "出现异常"+e.getMessage();
    }
}

然后需要该异常处理的Controller继承该基类

@Controller
@RequestMapping("/exception")
public class ExceptonController1 extends BaseController {

    @RequestMapping("/testBusinessException1")
    @ResponseBody
    public String testBusinessException(){
        throw new BusinessException();
    }
}

使用HandlerExceptionResolver

处理器异常解析器接口是负责处理各类控制器执行过程中出现的异常

public interface HandlerExceptionResolver {

   ModelAndView resolveException(
         HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
;

}

该方式是在DispatcherServlet中默认使用的,在processHandlerException()方法中,调用异常解析

protected ModelAndView processHandlerException(HttpServletRequest request, HttpServletResponse response,
      Object handler, Exception ex)
 throws Exception 
{

   // Check registered HandlerExceptionResolvers...
   ModelAndView exMv = null;
  // 异常处理器
   for (HandlerExceptionResolver handlerExceptionResolver : this.handlerExceptionResolvers) {
      exMv = handlerExceptionResolver.resolveException(request, response, handler, ex);
      if (exMv != null) {
         break;
      }
   }
   if (exMv != null) {
      if (exMv.isEmpty()) {
         request.setAttribute(EXCEPTION_ATTRIBUTE, ex);
         return null;
      }
      // We might still need view name translation for a plain error model...
      if (!exMv.hasView()) {
         exMv.setViewName(getDefaultViewName(request));
      }
      if (logger.isDebugEnabled()) {
         logger.debug("Handler execution resulted in exception - forwarding to resolved error view: " + exMv, ex);
      }
      WebUtils.exposeErrorRequestAttributes(request, ex, getServletName());
      return exMv;
   }

   throw ex;
}

其有四个实现类

DefaultHandlerExceptionResolver

DefaultHandlerExceptionResolver在DispatcherServlet中是默认使用的,用于将Spring中的标准异常解析为对应的HTTP状态码,但是响应体并不会改变

ResponseStatusExceptionResolver

ResponseStatusExceptionResolver在DispatcherServlet中是默认使用的,主要是和自定义异常上配置的@ResponseStatus注解进行搭配使用,将自定义异常映射到设定的HTTP状态码,与DefaultHandlerExceptionResolver一样,只是更改了状态码,并没有改变响应体

该异常处理机制是来解析@ResponseStatus来标注的异常

自定义异常

// code指定的是状态码,reason指定的是错误信息
@ResponseStatus(code = HttpStatus.BAD_REQUEST,reason = "出现业务异常")
public class BusinessException extends RuntimeException{

}
@RequestMapping("/testBusinessException")
@ResponseBody
public String testBusinessException(){
    throw new BusinessException();
}

调用该接口就会返回到状态码为400的错误页面

SimpleMappingExceptionResolver

SimpleMappingExceptionResolver用来映射异常类名到视图名

AnnotationMethodHandlerExceptionResolver

AnnotationMethodHandlerExceptionResolver通过注解@ExceptionHandler来处理异常,已经被废弃

ExceptionHandlerExceptionResolver
  • 如果出现异常,先是查找该Controller中用@ExceptionHandler注解定义的方法
  • 如果没有找到@ExceptionHandler注解的话,就会寻找标记了@ControllerAdvice注解的类中的@ExceptionHandler注解方法

除此之外,还可以自定义异常解析器,继承AbstractHandlerMethodExceptionResolver

自定义异常解析器
@Component
public class CustomExceptionResolver extends AbstractHandlerExceptionResolver {
    @Override
    protected ModelAndView doResolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
        if(ex instanceof BusinessException){
            System.out.println("出现业务异常");
            ModelAndView modelAndView = new ModelAndView();
            modelAndView.setStatus(HttpStatus.BAD_REQUEST);
            modelAndView.addObject("msg","出现业务异常");
            return modelAndView;
        }
        return null;
    }
}

但是由于该自定义解析依然返回的是ModelAndView,所以与目前前后端分离的项目不太搭

使用@ControllerAdvice+@ExceptionHandler

在前面的ExceptionHandlerExceptionResolver中已经用到了@ControllerAdvice,其实@ControllerAdvice是对于@ExceptionHandler的一个补充,使得可以进行全局的异常解析,可以将之前多个分散的@ExceptionHandler整合起来,合并成为一个单一的全局的异常处理中

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler
    @ResponseBody
    public String exception(Exception e){
        return "全局捕获: 出现异常"+e.getMessage();
    }
}
  • 它允许对响应体和HTTP状态码进行完全控制
  • 它允许将几个异常映射到相同的方法,以便一起处理
  • 它充分利用了新的REST风格的 ResposeEntity响应
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Component
public @interface ControllerAdvice {

   
   @AliasFor("basePackages")
   String[] value() default {};

   // 指定生效的包
   @AliasFor("value")
   String[] basePackages() default {};

   // 指定生效的包
   Class<?>[] basePackageClasses() default {};

   // 指定生效的类
   Class<?>[] assignableTypes() default {};

   // 指定生效的注解,如RestController
   Class<? extends Annotation>[] annotations() default {};

}
局部异常处理

在当前Controller中处理异常(当前Controller中使用@ExceptionHandler标注的方法)

@Controller
@RequestMapping("/exception")
public class ExceptionController {

  /**
  * 在@Controller中所写的@ExceptionHandler方法只能处理该Controller类中出现的异常,不可以处理其他Controller中出现的异常,此为局部异常处理
  */

    @ExceptionHandler
    @ResponseBody
    public String exception(Exception e){
        return "出现异常"+e.getMessage();
    }

    @RequestMapping("/testException")
    @ResponseBody
    public String testException(){
        User user = null;
        System.out.println(user.getId());
        return "success";
    }
}
全局异常处理

如果当前Controller中没有异常处理,则会使用全局异常(使用@ControllerAdvice标注的类中的@ExceptionHandler方法)

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler
    @ResponseBody
    public String exception(Exception e){
        return "全局捕获: 出现异常"+e.getMessage();
    }
}

也可以使用@RestControllerAdvice,相当于@ControllerAdvice+@ResponseBody

https://zhhll.icu/2021/框架/springmvc/基础/6.springmvc异常处理/

本文由 mdnice 多平台发布

http://www.ds6.com.cn/news/99329.html

相关文章:

  • 网站定制业务营销网站建设免费
  • 四川省建设工程招投标网站整合营销
  • 怎么用VS2012建设网站外链网站是什么
  • com网站域名百度竞价排名什么意思
  • 英雄联盟网站模版网络推广推广
  • 自助商城网站建设seo关键词快速排名软件
  • 创建wordpress主题南阳seo优化
  • 做网站需要什么配置服务器推广效果最好的平台
  • 做网站怎么切片网站建设
  • 人才网站 建设好 窗口百度公司排名
  • 做网站一定要买主机吗长沙网站seo方法
  • wordpress rest api评论seo的主要内容
  • 做新得网站可以换到原来得域名嘛百度seo公司兴田德润
  • wordpress iis 伪静态seo网站优化方
  • sae 企业网站职业培训网
  • 网站建设合同注意事项网站运营seo实训总结
  • 北京做微信网站足球世界排名
  • 网站设计与制治疗腰椎间盘突出的特效药
  • 哪个网站可以学做馒头网站如何被百度快速收录
  • 网站建设入门怎么推广自己的微信号
  • 南昌建设公司网站网站外包公司有哪些
  • 惠州百度推广排名优化网站专业术语中seo意思是
  • 网站交互图片怎么做百度后台登录
  • 网站免费搭建郑州网站营销推广
  • 公司网站建设需求书网络推广渠道公司
  • destoon 网站后台显示不出模板厦门零基础学seo
  • 网站页面做海报用什么软件中国搜索网站排名
  • 生物网站建设比较成功的网络营销案例
  • 案例网站免费crm客户管理系统
  • wordpress站点logo设置投稿网