spring 参数校验的统一报错

本文深入探讨了Spring框架中参数校验的功能,包括@Null、@NotNull等注解的使用,以及如何处理校验失败时的异常,实现统一的错误信息反馈。

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

spring本身提供了参数校验的功能,也就是在初始化一个对象的时候,对其进行值校验。spring通过在属性上添加注解的方式来提供校验的功能。这里的注解其实也是通过反射机制来实现。

这里说明一下spring的校验注解有:

   
@Null   被注释的元素必须为 null    
@NotNull    被注释的元素必须不为 null    
@AssertTrue     被注释的元素必须为 true    
@AssertFalse    被注释的元素必须为 false    
@Min(value)     被注释的元素必须是一个数字,其值必须大于等于指定的最小值    
@Max(value)     被注释的元素必须是一个数字,其值必须小于等于指定的最大值    
@DecimalMin(value)  被注释的元素必须是一个数字,其值必须大于等于指定的最小值    
@DecimalMax(value)  被注释的元素必须是一个数字,其值必须小于等于指定的最大值    
@Size(max=, min=)   被注释的元素的大小必须在指定的范围内    
@Digits (integer, fraction)     被注释的元素必须是一个数字,其值必须在可接受的范围内    
@Past   被注释的元素必须是一个过去的日期    
@Future     被注释的元素必须是一个将来的日期    
@Pattern(regex=,flag=)  被注释的元素必须符合指定的正则表达式

注解的用法:

直接在类的属性上添加相应的注解即可。

@ApiModel
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class UserManageAddRequest {

	@ApiModelProperty(name="userName",value="用户名称")
	@NotBlank(message="不能为空")
	private String username;
	
	@ApiModelProperty(name="loginid",value="手机号")
	@NotBlank(message="不能为空")
    @Pattern(regexp = "^\\d{11}$", message = "手机号码格式错误")
	private String loginid;
	
	@ApiModelProperty(name="userpassword",value="用户密码")
	@NotBlank(message="不能为空")
	private String userpassword;
	
	@ApiModelProperty(name="useremil",value="邮箱")
	@NotBlank(message="不能为空")
	private String useremil;
	
	@ApiModelProperty(name="roid",value="权限")
	@NotNull(message="不能为空")
    private Integer roid;
	
}

校验的如果发生作用:

要让我么的注解起到作用,需要在接收值得地方开启值校验的机制,这里使用@Vaild注解

	/**
	 * 添加用户
	 * @param user 用户
	 * @throws Exception 
	 */
	@PostMapping(value="/user-add",consumes="application/json",produces = "application/json;charset=utf-8")
	@ApiOperation(value="创建用户",notes="创建用户")
	public void userAdd(@Valid @RequestBody UserManageAddRequest user) throws Exception{
		UserDto dto=ModelMapUtils.map(user, UserDto.class);
		userManageServiceImp.createUser(dto);
		
	}

但是注解校验的报错是将报错的详细进行抛出,显然不是我们需要的,所以呐,我们需要进行进行统一的报错处理,这样前端也好处理。

Validation failed for argument [0] in public void com.inclination.scaffold.api.interfaces.UserManageApi.userAdd(com.inclination.scaffold.api.request.user.UserManageAddRequest) throws java.lang.Exception: [Field error in object 'userManageAddRequest' on field 'loginid': rejected value [string]; codes [Pattern.userManageAddRequest.loginid,Pattern.loginid,Pattern.java.lang.String,Pattern]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [userManageAddRequest.loginid,loginid]; arguments []; default message [loginid],[Ljavax.validation.constraints.Pattern$Flag;@133973b5,org.springframework.validation.beanvalidation.SpringValidatorAdapter$ResolvableAttribute@73a3d479]; default message [手机号码格式错误]]

我们期望的报错是这样的:

 但是我们知道这里注解报错的Exception为:MethodArgumentNotValidException   所以我么在@ControllerAdvice这里捕获这个异常,然后进行处理然后进行统一报错处理。详细代码如下:

	  @ResponseBody
	  @ExceptionHandler(MethodArgumentNotValidException.class)
	  public Error exceptionHander(HttpServletRequest req, MethodArgumentNotValidException e){
		  List<ObjectError> errorList=e.getBindingResult().getAllErrors();
		  String error="";
		  for (ObjectError objectError : errorList) {
			  error=objectError.getDefaultMessage();
		}	  
		  Error ew=new Error("0001",error);
	      return ew; 
	  }

这里的Error为

public class Error {

	private String code;
	private String msg;
	public Error(String code2, String message) {
		// TODO Auto-generated constructor stub
		this.code=code2;
		this.msg=message;
	}
	public String getCode() {
		return code;
	}
	public void setCode(String code) {
		this.code = code;
	}
	public String getMsg() {
		return msg;
	}
	public void setMsg(String msg) {
		this.msg = msg;
	}
	
}

 

### 解决 Spring Boot Starter Validation 报错问题 当遇到 `spring-boot-starter-validation` 相关的错误时,通常是因为配置不当或依赖缺失。以下是几种常见的解决方案: #### 1. 添加必要的依赖项 确保项目中包含了 `spring-boot-starter-validation` 和其他可能需要的相关库。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency> ``` 如果使用的是 Hibernate Validator,则还需要添加相应的依赖[^1]。 #### 2. 配置验证注解 对于实体类字段上的约束条件,应正确应用 JSR-303 或者 Bean Validation API 提供的标准注解,例如 `@NotNull`, `@Size`, `@Email` 等。 ```java public class User { @NotBlank(message = "Name is mandatory") private String name; @Email(message = "Invalid email format") private String email; } ``` 这些注解可以帮助在运行期间自动触发参数校验逻辑,并返回友好的提示信息给前端调用方[^2]。 #### 3. 处理异常响应 为了更好地管理来自控制器层面上发生的 ConstraintViolationException 类型的全局异常,在应用程序入口处定义一个统一的异常处理器是非常有帮助的做法。 ```java @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(MethodArgumentNotValidException.class) public ResponseEntity<Object> 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); } } ``` 此方法能够捕获所有由表单提交引起的验证失败事件,并将其转换成易于理解的消息体发送回客户端[^3]。 通过以上措施可以有效减少因缺少适当设置而导致的各种潜在问题的发生几率。当然实际开发过程中还可能会碰到更多复杂情况,这时就需要具体分析具体的业务场景来做出调整了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值