@RequestBody在處理請求方法的參數列表中使用,它可以將請求主體中的參數綁定到一個對象中,請求主體參數是通過HttpMessageConverter傳遞的,根據請求主體中的參數名與對象的屬性名進行匹配並綁定值。此外,還可以通過@Valid注解對請求主體中的參數進行校驗。
import com.example.demo.pojo.User; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; import javax.validation.Valid; /** * @Author: luoye * @Date: 2018-10-12 */ @RestController public class ValiController { @PostMapping(value = "/",produces = "application/json;charset=UTF-8") public User vali(@RequestBody @Valid User user){ return user; } }
自定義實體類
import javax.validation.constraints.Max; import javax.validation.constraints.NotBlank; import javax.validation.constraints.NotNull; /** * @Author: luoye * @Date: 2018-10-12 */ public class User { @NotBlank(message = "這個姓名不能為空") private String name; @NotNull(message = "這個年齡不能為空") @Max(value = 105,message = "太大了") private Integer age; public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } }
自定義全局異常處理器
import com.example.demo.pojo.ErrorMsg; import org.springframework.validation.BindingResult; import org.springframework.validation.FieldError; import org.springframework.validation.ObjectError; import org.springframework.web.bind.MethodArgumentNotValidException; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ResponseBody; import java.util.ArrayList; import java.util.List; /** * @Author luoye * @Date: 2018/10/12 16:50 */ @ControllerAdvice public class ExceptionHandlerContrller { @ExceptionHandler(MethodArgumentNotValidException.class) @ResponseBody public List<ErrorMsg> exception(MethodArgumentNotValidException e) { BindingResult bindingResult = e.getBindingResult(); List<ObjectError> allErrors = bindingResult.getAllErrors(); List<ErrorMsg> errorMsgs = new ArrayList<>(); allErrors.forEach(objectError -> { ErrorMsg errorMsg = new ErrorMsg(); FieldError fieldError = (FieldError)objectError; errorMsg.setField(fieldError.getField()); errorMsg.setObjectName(fieldError.getObjectName()); errorMsg.setMessage(fieldError.getDefaultMessage()); errorMsgs.add(errorMsg); }); return errorMsgs; } }
附錄
@Valid 注解類型的使用:
@Null
限制只能為null@NotNull
限制必須不為null@AssertFalse
限制必須為false@AssertTrue
限制必須為true@DecimalMax(value)
限制必須為一個不大於指定值的數字@DecimalMin(value)
限制必須為一個不小於指定值的數字@Digits(integer,fraction)
限制必須為一個小數,且整數部分的位數不能超過integer,小數部分的位數不能超過fraction@Future
限制必須是一個將來的日期@Max(value)
限制必須為一個不大於指定值的數字@Min(value)
限制必須為一個不小於指定值的數字@Past
限制必須是一個過去的日期@Pattern(value)
限制必須符合指定的正則表達式@Size(max,min)
限制字符長度必須在min到max之間@Past
驗證注解的元素值(日期類型)比當前時間早@NotEmpty
驗證注解的元素值不為null且不為空(字符串長度不為0、集合大小不為0)@NotBlank
驗證注解的元素值不為空(不為null、去除首位空格后長度為0),不同於@NotEmpty,@NotBlank只應用於字符串且在比較時會去除字符串的空格
驗證注解的元素值是Email,也可以通過正則表達式和flag指定自定義的email格式