1. 程式人生 > 程式設計 >SpringBoot整合Hibernate Validator實現引數驗證功能

SpringBoot整合Hibernate Validator實現引數驗證功能

在前後端分離的開發模式中,後端對前端傳入的引數的校驗成了必不可少的一個環節。但是在多引數的情況下,在controller層加上引數驗證,會顯得特別臃腫,並且會有許多的重複程式碼。這裡可以引用Hibernate Validator來解決這個問題,直接在實體類進行引數校驗,驗證失敗直接返回錯誤資訊給前端,減少controller層的程式碼量。

一、xml引入Hibernate Validator

<!-- 驗證器 -->
<dependency>
   <groupId>org.hibernate.validator</groupId>
   <artifactId>hibernate-validator</artifactId>
   <version>6.1.5.Final</version>
</dependency>

二、通過註解在實體類進行引數校驗

@Data
public class UserModel {

  @NotNull(message = "使用者名稱稱不能為空!")
  private String userName;

  @NotNull(message = "age不能為null!")
  @Range(min = 1,max = 888,message = "範圍為1至888")
  private Integer age;

  /**
   * 日期格式化轉換
   */
  @NotNull(message = "日期不能為null!")
  private Date date;
}

這裡用到的引數校驗的註解有@NotNull和@Range,message是到時候我們返回給前端的資訊,註解的具體意思如下:

  • @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(value) 被註釋的元素必須符合指定的正則表示式。
  • @Email 被註釋的元素必須是電子郵件地址
  • @Length 被註釋的字串的大小必須在指定的範圍內
  • @NotEmpty 被註釋的字串必須非空
  • @Range 被註釋的元素必須在合適的範圍內

三、controller層的方法加上@Valid註解

@PostMapping("/testPost")public Object testPost(@RequestBody @Valid UserModel userModel,BindingResult result){  
                          
		 if(result.hasErrors()){    for(ObjectError error:result.getAllErrors()){      
						                        return error.getDefaultMessage();   
					 } 
											    
				   }  
		return userModel;
}

controller層這裡只需要在實體類的前面加上@Valid註解,這個註解可以實現資料的驗證。這裡BindingResult是儲存了校驗時的錯誤資訊,驗證有誤時將錯誤資訊返回給前端。這裡不使用BindingResult的時候,控制檯會報MethodArgumentNotValidException,這裡可以通過自定義異常類來捕捉它,然後去掉BindingResult,以及難看的if判斷。

四、自定義異常類捕捉MethodArgumentNotValidException

@RestControllerAdvice
public class GlobalExceptionAdvice {

  @ExceptionHandler(value = MethodArgumentNotValidException.class)
  public JsonData validException(MethodArgumentNotValidException e) {
    //驗證post請求的引數合法性
    MethodArgumentNotValidException notValidException = e;
    String msg = notValidException.getBindingResult().getFieldError().getDefaultMessage();
    return JsonData.buildError(msg);
  }
}

使用PostMan的測試結果如下:

SpringBoot整合Hibernate Validator實現引數驗證功能

具體的程式碼可以在我的gitee上面 檢視 ,springboot_validator

到此這篇關於SpringBoot整合Hibernate Validator實現引數驗證功能的文章就介紹到這了,更多相關SpringBoot 引數驗證 內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!