SpringBoot 通过注解给属性添加校验并返回统一结果

1、添加HttpStatus的依赖包

<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpcore</artifactId>
    <version>4.4.15</version>
    <scope>compile</scope>
</dependency>

2、添加校验依赖包

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-validation</artifactId>
    <version>2.7.2</version>
</dependency>

3、定义一个统一的返回结果类R

package com.xu.common.utils;

import org.apache.http.HttpStatus;

import java.util.HashMap;
import java.util.Map;

/**
 * 返回数据
 */
public class R extends HashMap<String, Object> {
   private static final long serialVersionUID = 1L;

   public R setData(Object data){
		put("data",data);
		return this;
	}

	public <T> T getData(TypeReference<T> typeReference){
		Object data = get("data");
		String jsonString = JSON.toJSONString(data);
		T t = JSON.parseObject(jsonString, typeReference);
		return t;
	}
	public <T> T getData(String key,TypeReference<T> typeReference){
		Object data = get(key);
		String jsonString = JSON.toJSONString(data);
		T t = JSON.parseObject(jsonString, typeReference);
		return t;
	}

   public R() {
      put("code", 0);
      put("msg", "success");
   }
   
   public static R error() {
      return error(HttpStatus.SC_INTERNAL_SERVER_ERROR, "未知异常,请联系管理员");
   }
   
   public static R error(String msg) {
      return error(HttpStatus.SC_INTERNAL_SERVER_ERROR, msg);
   }
   
   public static R error(int code, String msg) {
      R r = new R();
      r.put("code", code);
      r.put("msg", msg);
      return r;
   }

   public static R ok(String msg) {
      R r = new R();
      r.put("msg", msg);
      return r;
   }
   
   public static R ok(Map<String, Object> map) {
      R r = new R();
      r.putAll(map);
      return r;
   }
   
   public static R ok() {
      return new R();
   }

   public R put(String key, Object value) {
      super.put(key, value);
      return this;
   }
}

4、枚举异常状态码

public enum ErrorCodeEnume {

    UNKNOW_EXCEPTION(10000,"系统未知异常"),
    VAILD_EXCEPTION(10001,"参数格式校验失败");

    private int code;
    private String msg;
    BizCodeEnume(int code,String msg){
        this.code = code;
        this.msg = msg;
    }

    public int getCode() {
        return code;
    }

    public String getMsg() {
        return msg;
    }
}

5、在需要校验的实体类的属性上添加注解

@NotBlank(message = "用户名不能为空")
private String name;

6.1、在controller中添加 @valid注解与BindingResult

@RequestMapping("/save")
public R save(@Valid @RequestBody User user, BindingResult result) {
    if (result.hasErrors()) {
        Map<String,String> map = new HashMap<>();
        result.getFieldErrors().forEach((item)->{
            String message = item.getDefaultMessage();
            String field = item.getField();
            map.put(field,message);
        });
        return R.error(ErrorCodeEnume.VAILD_EXCEPTION.getCode(), ErrorCodeEnume.VAILD_EXCEPTION.getMsg()).put("data",map);
    }
    else
    {
        UserService.save(user);
    }
    return R.ok();
}

6.2或者利用RestControllerAdvice注解将异常统一抛出(这个注解利用AOP原理)

import com.xu.common.utils.R;
import lombok.extern.slf4j.Slf4j;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.*;

import java.util.HashMap;
import java.util.Map;

@Slf4j
@RestControllerAdvice(basePackages = "需要检测异常的包名,一般为controller包")
public class ExceptionController {
    @ExceptionHandler(value = MethodArgumentNotValidException.class)
    public R handleVaildException(MethodArgumentNotValidException e){
        Map<String,String> map = new HashMap<>();
        BindingResult result = e.getBindingResult();
        result.getFieldErrors().forEach((item)->{
            String message = item.getDefaultMessage();
            String field = item.getField();
            map.put(field,message);
        });
        log.error("数据校验出现问题{}",map);
       return R.error(ErrorCodeEnume.VAILD_EXCEPTION.getCode(), ErrorCodeEnume.VAILD_EXCEPTION.getMsg()).put("data",map);
    }
}

@ExceptionHandler(value = Throwable.class)
public R handleException(Throwable throwable)
{
    return R.error(ErrorCodeEnume.UNKNOW_EXCEPTION.getCode(), ErrorCodeEnume.UNKNOW_EXCEPTION.getMsg());
}

7、通过postman测试返回结果

  "msg": "提交的数据不合法",

    "code": 400,

    "data": {

        "name": "用户名不能为空"

    }


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot提供了一套方便的校验注解,可以用于对请求参数进行校验。下面是一些常用的校验注解: 1. @NotNull:验证注解的元素值不为null。 2. @NotEmpty:验证注解的元素值不为null且不为空。 3. @NotBlank:验证注解的元素值不为null且去除首尾空格后不为空。 4. @Min:验证注解的元素值大于等于指定的最小值。 5. @Max:验证注解的元素值小于等于指定的最大值。 6. @Size:验证注解的元素值的大小在指定范围内。 7. @Pattern:验证注解的元素值符合指定的正则表达式。 8. @Email:验证注解的元素值是一个有效的电子邮件地址。 使用这些注解,可以在Controller层的请求参数上进行标记,然后在处理请求的方法中使用@Valid注解进行参数校验。如果校验失败,会抛出MethodArgumentNotValidException异常,可以通过ExceptionHandler进行统一处理。 例如,对一个User对象进行校验: ```java public class User { @NotBlank(message = "用户名不能为空") private String username; @Size(min = 6, max = 20, message = "密码长度必须在6到20之间") private String password; // 省略getter和setter } @RestController public class UserController { @PostMapping("/users") public void createUser(@Valid @RequestBody User user) { // 处理创建用户的逻辑 } // 异常处理 @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 ResponseEntity.badRequest().body(errors); } } ``` 在上面的例子中,@NotBlank注解用于校验username字段不能为空,@Size注解用于校验password字段的长度必须在6到20之间。`@Valid`注解用于标记需要进行校验的参数,当校验失败时,会抛出MethodArgumentNotValidException异常,可以通过ExceptionHandler进行统一处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值