异常处理是构建健壮且用户友好的应用程序的关键部分。在 spring boot 中,我们可以通过多种方式处理异常,以确保我们的应用程序保持稳定并向用户提供有意义的反馈。本指南将涵盖异常处理的不同策略,包括自定义异常、全局异常处理、验证错误和生产最佳实践。
- 异常处理基础知识
异常是扰乱程序正常流程的事件。它们可以分为:
checked exceptions: 在编译时检查的异常。
unchecked exceptions(运行时异常): 运行时发生的异常。
错误: 应用程序不应处理的严重问题,例如 outofmemoryerror。
- 自定义异常类
创建自定义异常类有助于处理应用程序中的特定错误情况。
package com.example.springbootrefresher.exception;
public class departmentnotfoundexception extends runtimeexception {
public departmentnotfoundexception(string message) {
super(message);
}
}
登录后复制
- 控制器中的异常处理
@exceptionhandler 注释:
您可以在控制器类中定义处理异常的方法。
package com.example.springbootrefresher.controller;
import com.example.springbootrefresher.exception.departmentnotfoundexception;
import org.springframework.http.httpstatus;
import org.springframework.http.responseentity;
import org.springframework.web.bind.annotation.exceptionhandler;
import org.springframework.web.bind.annotation.getmapping;
import org.springframework.web.bind.annotation.restcontroller;
@restcontroller
public class departmentcontroller {
@getmapping("/department")
public string getdepartment() {
// simulate an exception
throw new departmentnotfoundexception("department not found!");
}
@exceptionhandler(departmentnotfoundexception.class)
public responseentity<string> handledepartmentnotfoundexception(departmentnotfoundexception ex) {
return new responseentity(ex.getmessage(), httpstatus.not_found);
}
}
登录后复制
- 使用@controlleradvice进行全局异常处理
要全局处理异常,可以使用@controlleradvice和集中式异常处理程序。
package com.example.springbootrefresher.error;
import com.example.springbootrefresher.entity.errormessage;
import com.example.springbootrefresher.exception.departmentnotfoundexception;
import org.springframework.http.httpstatus;
import org.springframework.http.responseentity;
import org.springframework.web.bind.annotation.controlleradvice;
import org.springframework.web.bind.annotation.exceptionhandler;
import org.springframework.web.bind.annotation.responsestatus;
import org.springframework.web.context.request.webrequest;
import org.springframework.web.servlet.mvc.method.annotation.responseentityexceptionhandler;
@controlleradvice
@responsestatus
public class customresponseentityexceptionhandler extends responseentityexceptionhandler {
@exceptionhandler(departmentnotfoundexception.class)
public responseentity<errormessage> handledepartmentnotfoundexception(departmentnotfoundexception exception, webrequest request) {
errormessage message = new errormessage(
httpstatus.not_found.value(),
exception.getmessage(),
request.getdescription(false)
);
return responseentity.status(httpstatus.not_found)
.body(message);
}
@exceptionhandler(exception.class)
public responseentity<errormessage> handleglobalexception(exception exception, webrequest request) {
errormessage message = new errormessage(
httpstatus.internal_server_error.value(),
exception.getmessage(),
request.getdescription(false)
);
return responseentity.status(httpstatus.internal_server_error)
.body(message);
}
}
登录后复制
- 创建标准错误响应
定义标准错误响应类来构建错误消息。
package com.example.springbootrefresher.entity;
public class errormessage {
private int statuscode;
private string message;
private string description;
public errormessage(int statuscode, string message, string description) {
this.statuscode = statuscode;
this.message = message;
this.description = description;
}
// getters and setters
public int getstatuscode() {
return statuscode;
}
public void setstatuscode(int statuscode) {
this.statuscode = statuscode;
}
public string getmessage() {
return message;
}
public void setmessage(string message) {
this.message = message;
}
public string getdescription() {
return description;
}
public void setdescription(string description) {
this.description = description;
}
}
登录后复制
- 处理验证错误
spring boot 与 bean validation (jsr-380) 集成良好。要全局处理验证错误,请使用@controlleradvice。
package com.example.springbootrefresher.error;
import org.springframework.http.httpstatus;
import org.springframework.http.responseentity;
import org.springframework.validation.fielderror;
import org.springframework.web.bind.methodargumentnotvalidexception;
import org.springframework.web.bind.annotation.controlleradvice;
import org.springframework.web.bind.annotation.exceptionhandler;
import org.springframework.web.bind.annotation.responsestatus;
import org.springframework.web.context.request.webrequest;
import java.util.hashmap;
import java.util.map;
@controlleradvice
@responsestatus
public class validationexceptionhandler extends responseentityexceptionhandler {
@exceptionhandler(methodargumentnotvalidexception.class)
public responseentity<map string>> handlevalidationexceptions(methodargumentnotvalidexception ex) {
map<string string> errors = new hashmap();
ex.getbindingresult().getallerrors().foreach((error) -> {
string fieldname = ((fielderror) error).getfield();
string errormessage = error.getdefaultmessage();
errors.put(fieldname, errormessage);
});
return new responseentity(errors, httpstatus.bad_request);
}
}
登录后复制
- 使用@responsestatus处理简单异常
对于简单的情况,可以用@responsestatus注解异常类来指定http状态码。
package com.example.SpringBootRefresher.exception;
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.ResponseStatus;
@ResponseStatus(HttpStatus.NOT_FOUND)
public class DepartmentNotFoundException extends RuntimeException {
public DepartmentNotFoundException(String message) {
super(message);
}
}
登录后复制
- 生产最佳实践
一致的错误响应:确保您的应用程序返回一致且结构化的错误响应。使用标准错误响应类。
日志记录: 记录异常以用于调试和监控目的。确保敏感信息不会在日志中暴露。
用户友好的消息:提供用户友好的错误消息。避免向用户暴露内部细节或堆栈跟踪。
安全: 请谨慎对待错误响应中包含的信息,以免暴露敏感数据。
文档: 为您的团队和未来的维护人员记录您的异常处理策略。
概括
spring boot 中的异常处理涉及使用 @exceptionhandler、@controlleradvice 和 @responsestatus 等注释来有效地管理错误。通过创建自定义异常、处理验证错误并遵循最佳实践,您可以构建强大的应用程序,以优雅地处理错误并向用户提供有意义的反馈。使用 java 17 功能可确保您的应用程序利用 java 生态系统中的最新改进。
以上就是Spring Boot 中的异常处理的详细内容,更多请关注php中文网其它相关文章!
91资源网站长-冰晨2024-08-27 17:15
发表在:【账号直充】爱奇艺黄金VIP会员『1个月』官方直充丨立即到账丨24小时全天秒单!不错不错,价格比官方便宜
91资源网站长-冰晨2024-08-27 16:15
发表在:2022零基础Java入门视频课程不错,学习一下