springMVC 全局异常统一处理

devtools/2024/11/27 20:06:14/

全局异常处理⽅式⼀:

1、配置简单异常处理器

配置 SimpleMappingExceptionResolver 对象:

<!-- 配置全局异常统⼀处理的 Bean (简单异常处理器) -->

<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">

<!-- ⻚⾯在转发时出现异常,设置默认的错误⻚⾯ (error代表的是⼀个视图) -->

<property name="defaultErrorView" value="error"></property>

<!-- 异常发⽣时,设置异常的变量名 -->

<property name="exceptionAttribute" value="ex"></property>

</bean>

可以在处理异常的⻚⾯获取异常信息

${ex}

2、 使⽤⾃定义异常

1.参数异常:
/**
* ⾃定义异常:参数异常
*/
public class ParamsException extends RuntimeException {
private Integer code = 300 ;
private String msg = " 参数异常 !" ;
public ParamsException () {
super ( " 参数异常 !" );
}
public ParamsException ( String msg ) {
super ( msg );
this . msg = msg ;
}
public ParamsException ( Integer code ) {
super ( " 参数异常 !" );
this . code = code ;
}
public ParamsException ( Integer code , String msg ) {
super ( msg );
this . code = code ;
this . msg = msg ;
}
public Integer getCode () {
return code ;
}
public void setCode ( Integer code ) {
this . code = code ;
}
public String getMsg () {
return msg ;
}
public void setMsg ( String msg ) {
this . msg = msg ;
}
}
2.业务异常:
/**
* ⾃定义异常:业务异常
*/
public class BusinessException extends RuntimeException {
private Integer code = 400 ;
private String msg = " 业务异常 !" ;
public BusinessException () {
super ( " 业务异常 !" );
}
public BusinessException ( String msg ) {
super ( msg );
this . msg = msg ;
}
public BusinessException ( Integer code ) {
super ( " 业务异常 !" );
this . code = code ;
}
public BusinessException ( Integer code , String msg ) {
super ( msg );
this . code = code ;
this . msg = msg ;
}
public Integer getCode () {
return code ;
}
public void setCode ( Integer code ) {
this . code = code ;
}
public String getMsg () {
return msg ;
}
public void setMsg ( String msg ) {
this . msg = msg ;
}
}

3.、设置⾃定义异常与⻚⾯的映射

<!-- 设置⾃定义异常与⻚⾯的映射 -->

<property name="exceptionMappings">

<props>

<!-- key:⾃定义异常对象的路径; 标签中设置具体的处理⻚⾯的视图名-->

<prop key="com.xxxx.ssm.exception.BusinessException">error</prop>

<prop key="com.xxxx.ssm.exception.ParamsException">error</prop>

</props>

</property>

使⽤ SimpleMappingExceptionResolver 进⾏异常处理,具有集成简单、有良好的扩展性、对已有代码 没有⼊侵性等优点,但该⽅法仅能获取到异常信息,若在出现异常时,对需要获取除异常以外的数据的情况不适⽤。

全局异常处理方式二(推荐):

1、实现 HandlerExceptionResolver 接⼝

/**

* 全局异常统⼀处理

*/

@Component

public class GlobalExceptionResolver implements HandlerExceptionResolver {

@Override

public ModelAndView resolveException(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse, Object handler, Exception ex) {

ModelAndView mv = new ModelAndView("error");

mv.addObject("ex","默认错误信息");

return mv;

}

}

.2. ⾃定义异常处理

/**

* 全局异常统⼀处理

*/

@Component

public class GlobalExceptionResolver implements HandlerExceptionResolver {

@Override

public ModelAndView resolveException(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse, Object handler, Exception ex) {

ModelAndView mv = new ModelAndView("error");

mv.addObject("ex","默认错误信息");

// 判断是否是⾃定义异常

if (ex instanceof ParamsException) {

mv.setViewName("params_error");

ParamsException e = (ParamsException) ex;

mv.addObject("ex", e.getMsg());

}

if (ex instanceof BusinessException) {

mv.setViewName("business_error");

BusinessException e = (BusinessException) ex;

mv.addObject("ex", e.getMsg());

}

return mv;

}

}

使⽤实现 HandlerExceptionResolver 接⼝的异常处理器进⾏异常处理,具有集成简单、有良好的扩展
性、对已有代码没有⼊侵性等优点,同时,在异常处理时能获取导致出现异常的对象,有利于提供更详
细的异常处理信息。

全局异常处理⽅式三:

⻚⾯处理器继承 BaseController:

public class BaseController {

@ExceptionHandler

public String exc(HttpServletRequest request,HttpServletResponse

response,Exception ex){

request.setAttribute("ex", ex);

if(ex instanceof ParamsException){

return "error_param";

}

if(ex instanceof BusinessException){

return "error_business";

}

return "error";

}

}

使⽤ @ExceptionHandler 注解实现异常处理,具有集成简单、有扩展性好(只需要将要异常处理的
Controller 类继承于 BaseController 即可)、不需要附加 Spring 配置等优点,但该⽅法对已有代码存在⼊
侵性 ( 需要修改已有代码,使相关类继承于 BaseController) ,在异常处理时不能获取除异常以外的数据。

未捕获异常的处理:

对于 Unchecked Exception ⽽⾔,由于代码不强制捕获,往往被忽略,如果运⾏期产⽣了Unchecked Exception,⽽代码中⼜没有进⾏相应的捕获和处理,则我们可能不得不⾯对尴尬的 404 500……等服 务器内部错误提示⻚⾯。

此时需要⼀个全⾯⽽有效的异常处理机制。⽬前⼤多数服务器也都⽀持在 web.xml 中通过(Websphere/Weblogic)或者(Tomcat)节点配置特定异常情况的显示⻚⾯。修改 web.xml ⽂件,增加以下内 容:

<!-- 出错⻚⾯定义 -->

<error-page>

<exception-type>java.lang.Throwable</exception-type>

<location>/500.jsp</location>

</error-page>

<error-page>

<error-code>500</error-code>

<location>/500.jsp</location>

</error-page>

<error-page>

<error-code>404</error-code>

<location>/404.jsp</location>

</error-page>


http://www.ppmy.cn/devtools/137478.html

相关文章

分析电平转换电路导致MCU通讯速率受限的原因

一、问题背景与电平转换电路的重要性 在现代嵌入式系统中,微控制单元(MCU)与其他模块之间的通信速率是关键的性能指标之一。在多种接口通信中,尤其是当不同电平标准的设备进行连接时,电平转换电路成为确保信号正确传输的核心部分。然而,当电平转换电路不匹配时,可能会导…

基于Java Springboot高校工作室管理系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 数据…

突破Zustand的局限性:与React ContentAPI搭配使用

Zustand在状态管理中是非常适手的工具&#xff0c;在很多场景中我们都可以用它来解决复杂问题. 但是由于Zustand的设计理念&#xff0c;它仍然有一些限制&#xff0c;在这里用官网中的小demo举一个很简单的例子&#xff1a; import { create } from zustand type CountStore …

YOLOv8实战木材缺陷识别

本文采用YOLOv8作为核心算法框架&#xff0c;结合PyQt5构建用户界面&#xff0c;使用Python3进行开发。YOLOv8以其高效的实时检测能力&#xff0c;在多个目标检测任务中展现出卓越性能。本研究针对木材缺陷数据集进行训练和优化&#xff0c;该数据集包含丰富的木材缺陷图像样本…

git如何给历史提交打标签

git如何给历史提交打标签 如果忘记给某个提交打标签&#xff0c;可以在之后补上 在项目所在文件夹&#xff0c;右键git bash here 查看历史标签&#xff1a; git tag创建标签&#xff1a; git tag -a 标签名号 commitSHA(历史提交校验码) -m 提交信息 git tag -a v1.0.0.…

pyhton+yaml+pytest+allure框架封装-全局变量渲染

我们在日常测试中 会有一个接口中多个值的情况 比如这种 { "name": "thread", "value": "4986-MainThread", "status": "framework", "start": "pytest", …

极狐GitLab 17.6 正式发布几十项与 DevSecOps 相关的功能【六】

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料&#xff1a; 极狐GitLab 官网极狐…

Failed to find SV in PRN block of SINEX file (Name svnav.dat)

gamit 精密星历生成失败 gamit svnav.dat没更新 下载svnav.dat.allgnss 重命名成 svnav.dat ,替换到tables&#xff0c;即可。