博客
关于我
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/

    你可能感兴趣的文章
    navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
    查看>>
    Navicat 设置时间默认值(当前最新时间)
    查看>>
    navicat 连接远程mysql
    查看>>
    navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
    查看>>
    Navicate for mysql 数据库设计-数据库分析
    查看>>
    Navicat下载和破解以及使用
    查看>>
    Navicat中怎样将SQLServer的表复制到MySql中
    查看>>
    navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
    查看>>
    Navicat可视化界面导入SQL文件生成数据库表
    查看>>
    Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
    查看>>
    Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
    查看>>
    Navicat如何连接MySQL
    查看>>
    navicat导入.sql文件出错2006- MySQLserver has gone away
    查看>>
    Navicat导入海量Excel数据到数据库(简易介绍)
    查看>>
    Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
    查看>>
    navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
    查看>>
    navicat怎么导出和导入数据表
    查看>>
    Navicat报错connection is being used
    查看>>
    Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
    查看>>
    Navicat控制mysql用户权限
    查看>>