溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring @Valid @Validated實現(xiàn)驗證的方法

發(fā)布時間:2021-05-28 10:53:10 來源:億速云 閱讀:126 作者:小新 欄目:編程語言

小編給大家分享一下Spring @Valid @Validated實現(xiàn)驗證的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

對于屬性的驗證有如下一些注解
@NotBlank:只用在String上,值不能為null,并且trim后長度大于零。不為null,不是全為空格的字符串
@NotNull: 不能為null,但可以是長度為零的字符串
@NotEmpty: 不能為null,長度大于零
@Null:必須為null
@Min(value): 數(shù)字,值必須大于等于指定的值
@Max(value): 數(shù)字,值必須小雨等于指定的值
@DecimalMin(value): 數(shù)字,值必須大于等于指定的值
@DecimalMax(value): 數(shù)字,值必須小雨等于指定的值
@Digits(integer, fraction):數(shù)字,值必須在可接收的范圍內(nèi)@Digits(integer=3, fraction=2) 111.22是符合要求的,1111.22不符合,整數(shù)部分4位所以不符合要求
@Size(min=v1,max=v2): v1<=值<=v2
@AssertTrue: 必須為true
@AssertFalse: 必須為false
@Past: 必須是過去的日期
@Future: 必須是將來的日期
@Pattern(regex=, flag=): 符合指定的正則表達式

@Valid:可以用在方法參數(shù),方法,屬性上。用來進行嵌套驗證。嵌套驗證就是在ClassA的屬性中有ClassB,而ClassB的屬性也需要進行驗證。

@Validated:可以用在方法參數(shù),方法上,不能用在屬性上。提供了分組的功能,在參數(shù)傳入時根據(jù)分組采用不同的驗證機制。說明一下分組,例如對于User的userID,在新建用戶時userID必須要為null。在更新用戶時userID必須要不為空并且不能都是空格(blank)。這就對userID進行了分組功能,Add和Update兩個組。

@Valid實例

Book定義

public class Book {

  @NotBlank(message = "bookID is mandatory, can not be blank")
  public String bookID;
  
  @Size(min=5, max=20)
  @NotBlank(message = "bookName is mandatory, can not be blank")
  public String bookName;
  public String author;
  
  @Valid
  public List<ChapterInfo> chapterList;
  
  public Book(String id, String name, String auth) {
    bookName = name;
    author = auth;
    bookID = id;
  }
}

ChapterInfo定義

public class ChapterInfo {
  @Min(0)
  public Long chapterID;
  
  @NotBlank
  @Size(min=5, max=50)
  public String chapterName;
  
  @Size(min=5, max=20)
  public String contentID;
}

BookController

@RestController
@RequestMapping("/bookcontroller")
public class BookController {

  private List<Book> bookList = new ArrayList();
  
  @ResponseBody
  @RequestMapping("/addBookToList")
  public boolean addBookToList(@Valid @RequestBody Book b) {
    System.out.println(b.bookName);
    
    bookList.add(b);
    
    return true;
  }
  
  @InitBinder
  private void activateDirectFieldAccess(DataBinder dataBinder) {
    dataBinder.initDirectFieldAccess();
  }
  
}

Postman驗證

Spring @Valid @Validated實現(xiàn)驗證的方法

可以看到chapterList中的ChapterInfo的chapterName為blank,驗證不通過

@Validated實例

public class User {
  
  @NotBlank
  public String name;
  
  @NotBlank
  public String address;
  
  @Min(1)
  public int age;

  public boolean isMan;
  
  @NotBlank(groups = {Update.class})
  @Null(groups = {Add.class})
  public String usrID;
  
  public interface Add{}
  
  public interface Update{}
  
  
  public User(String name, String addr, int age, boolean isMan) {
    this.name = name;
    this.address = addr;
    this.age = age;
    this.isMan = isMan;
  }

}

其中對usrID屬性使用了@NotBlank(groups = {Update.class})和@Null(groups = {Add.class})注釋。意思是:
(1)Update user時usrID不能為blank(要通過usrID查找user去update)
(2)Add user時usrID必須為空(要生成新的user,會分配user ID)

@RestController
@RequestMapping("/registcontroller")
public class RegistController {

  List<User> usrList = new ArrayList();
  
  
  @PostMapping(path="/adduser")
  @ResponseBody
  public User addUser(@RequestBody @Validated({User.Add.class}) User usr, BindingResult result) {
    
    if (result.hasErrors()) {
      List<ObjectError> list = result.getAllErrors();
      FieldError error = (FieldError)list.get(0);
      System.out.println(error.getObjectName() + "," + error.getField() + "," + error.getDefaultMessage());
      return null;
    }
    User user = new User(usr.name, usr.address, usr.age, usr.isMan);
    String usrID = usrList.size() + "";
    
    user.usrID = usrID;
    
    return user;
  }
}

在addUser的傳入?yún)?shù)進行了Validated的分組驗證(Add),如果傳入User的usrID不為blank則會出錯。

PostMan驗證

usrID不存在時

Spring @Valid @Validated實現(xiàn)驗證的方法

正常返回新添加的user

指定usrID時

Spring @Valid @Validated實現(xiàn)驗證的方法

Spring @Valid @Validated實現(xiàn)驗證的方法

出錯

以上是“Spring @Valid @Validated實現(xiàn)驗證的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI