SpringMVC自定义异常处理器

本文介绍了SpringMVC框架中如何自定义异常处理器,包括区分可预知异常和不可预知异常,以及如何处理这两种类型的异常。通过自定义异常类型和实现handlerExceptionResolver接口,可以创建个性化的异常处理策略。同时,文章还讨论了前端如何处理返回的异常信息,包括JSON和JSP页面的情况,并展示了相关的XML配置文件示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常可以分为两类:
1.可预知异常
2.不可预知异常(即runtime异常)
前者是程序员主动抛出的异常,为了给用户提示,后者可以通过提高代码质量来避免

本项目使用了ssm框架,即异常通过dao->service->action抛出,最后前端控制器中的异常处理器来捕获处理异常。

  1. 自定义异常类型
    代码如下:
/**
 * 自定义异常类型,成员为ResultInfo,用来储存错误信息以及提示
 * @author x
 *
 */

import com.summerzhou.base.process.result.ResultInfo;

public class ExceptionResultInfo extends Exception {
	private ResultInfo resultInfo;
	
	public ExceptionResultInfo(ResultInfo resultInfo) {
		super(resultInfo.getMessage());
		this.resultInfo = resultInfo;
	}

	public ResultInfo getResultInfo() {
		return resultInfo;
	}

	public void setResultInfo(ResultInfo resultInfo) {
		this.resultInfo = resultInfo;
	}
	
	
}

其中的ResultInfo储存了异常信息

public class ResultInfo
{
	public static final int TYPE_RESULT_FAIL = 0;//失败
	public static final int TYPE_RESULT_SUCCESS = 1;//成功
	public static final int TYPE_RESULT_WARN = 2;//警告
	public static final int TYPE_RESULT_INFO = 3;//提示信息
	
	public ResultInfo(){}

	/**
	 * 消息提示类型
	 */
	private int type;
		
	
	/**
	 * 提示代码
	 */
	private int messageCode;
	
	   
	/**
	 * 提示信息
	 */
	private String message;
	
	
	/**
	 * 提示信息明细列表
	 */
	private List<ResultInfo> details;
}

对于上述的两种异常,如果捕获的是自定义的异常,直接获取里面封装的信息类
如果捕捉的是runtime Exception,则构造一个自定义的错误异常

//如果是自定义的Exception,则直接返回其中的消息信息
//如果是runtime Exception,则构建一个新的自定义异常
if(e instanceof ExceptionResultInfo) {
	return (ExceptionResultInfo)e;
}else {
	ResultInfo resultInfo = new ResultInfo(ResultInfo.TYPE_RESULT_FAIL, "未知错误");
	return new ExceptionResultInfo(resultInfo);
}
  1. 自定义异常处理器
    springmvc中有一个自动注册的异常处理器,即detectAllHandlerExceptionResolvers类。如果需要使用自定义的异常处理器,则实现handlerExceptionResolver接口即可
public interface HandlerExceptionRes
### 如何在 Spring MVC 中配置自定义 404 错误页面 为了实现更友好的用户体验,当请求资源不存在时可以展示定制化的错误页面。对于Spring Boot应用而言,可以通过多种方式来设置自定义的404错误页面。 #### 方法一:利用静态文件夹下的特定命名规则创建HTML文件 如果应用程序是基于Spring Boot构建,则只需简单地将名为`404.html`的文件放置于`src/main/resources/static/`目录下即可[^1]。这种方式适用于希望快速提供简单的静态响应场景。 ```html <!-- src/main/resources/static/404.html --> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Page Not Found</title> </head> <body> <h1>The page you're looking for doesn't exist.</h1> <p>Please check the URL or go back to home page.</p> <a href="/">Go Home</a> </body> </html> ``` #### 方法二:通过Java代码配置全局异常处理器并指定视图解析器路径 另一种更为灵活的方法是在项目中编写一个实现了`ErrorController`接口的类,并重写其方法来自定义处理逻辑以及返回相应的模板页面[^2]。此法允许开发者更加精细地控制不同类型的HTTP状态码对应的呈现效果。 ```java // CustomBasicErrorController.java package com.example.demo.controller; import org.springframework.boot.web.servlet.error.ErrorController; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; @Controller public class CustomBasicErrorController implements ErrorController { private static final String PATH = "/error"; @RequestMapping(value=PATH) public String error(Model model){ // 可在此处添加更多业务逻辑判断 return "errors/error"; // 对应templates/errors/error.html或其他渲染引擎支持的形式 } @Override public String getErrorPath(){ return PATH; } } ``` 同时还需要确保有对应位置上的Thymeleaf或者其他模版引擎能够识别到的`.html`文件存在: ```html <!-- templates/errors/error.html --> <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <title th:text="${status}">Status Code</title> </head> <body> <div th:if="${status == '404'}"> <h1>Oops! The requested resource could not be found.</h1> <!-- 更多个性化设计... --> </div> <!-- 处理其他可能的状态码情况 --> </body> </html> ``` 此外,也可以采用XML方式进行web.xml中的<error-page/>标签声明具体的映射关系[^4];不过这种方法相对较为传统,在现代开发实践中较少被推荐使用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值