博客
关于我
SpringMVC处理异常
阅读量:556 次
发布时间:2019-03-09

本文共 1254 字,大约阅读时间需要 4 分钟。

Spring 提供了多种方式将异常转换为响应,这些机制可以帮助开发者更好地管理应用程序的错误处理流程。以下是一些关键信息:

  • 特定的Spring异常将会自动映射为指定的HTTP状态码:Spring内部有很多特定的异常类,这些异常会被自动映射到相应的HTTP状态码中。例如,当DispatcherServlet无法找到处理请求的方法时,会抛出NoSuchRequestHandlingMethodException异常,最终生成404状态码(Not Found)。

  • 使用@ResponseStatus注解将异常映射为特定状态码:通过在异常类上使用@ResponseStatus注解,可以指定要映射到的具体HTTP状态码。例如,SpittleNotFound-Exception异常可以被映射到404状态码。

  • 在控制器方法上使用@ExceptionHandler注解处理异常:@ExceptionHandler注解可以用来在控制器方法中定义处理特定异常的逻辑。这样的方法可以接收任何异常类型,并根据需要返回处理结果。

  • 使用@controllerAdvice来集中管理异常处理:通过定义一个带有@controllerAdvice注解的类,可以集中管理应用程序中所有控制器方法抛出的异常。这种方式有助于减少重复代码,并统一处理异常。

  • 以下是如何在Spring应用中配置这些机制的具体步骤:

    • 创建一个新的异常处理类,例如''
      @ControllerAdvicepublic class ZzfExceptionHandler {    public static final String IMOOC_ERROR_VIEW = "error";    @ExceptionHandler(value = Exception.class)    public ModelAndView errorHandler(HttpServletRequest request, HttpServletResponse response, Exception e) throws Exception {        e.printStackTrace();        ModelAndView mav = new ModelAndView();        mav.addObject("exception", e);        mav.addObject("url", request.getRequestURL());        mav.setViewName(IMOOC_ERROR_VIEW);        return mav;    }}

      这个类会处理所有控制器抛出的异常,将其转换为视图响应,并跳转到templates/error.html

    这样,不管应用程序中哪个控制器方法抛出异常,都可以通过这个统一的异常处理逻辑来处理。这个方法确保了错误信息的一致性和可追踪性,同时也使代码更加简洁和易于维护。

    转载地址:http://ommsz.baihongyu.com/

    你可能感兴趣的文章
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>
    MySQL 快速创建千万级测试数据
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    MySql 手动执行主从备份
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>