中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

SpringBoot如何優雅的處理校驗參數的方法

發布時間:2020-09-12 21:37:16 來源:腳本之家 閱讀:132 作者:TopJavaer 欄目:編程語言

前言

做web開發有一點很煩人就是要校驗參數,基本上每個接口都要對參數進行校驗,比如一些格式校驗 非空校驗都是必不可少的。如果參數比較少的話還是容易 處理的一但參數比較多了的話代碼中就會出現大量的IF ELSE就比如下面這樣:

 SpringBoot如何優雅的處理校驗參數的方法

這個例子只是校驗了一下空參數。如果需要驗證郵箱格式和手機號格式校驗的話代碼會更多,所以介紹一下validator通過注解的方式進行校驗參數。

什么是Validator

Bean Validation是Java定義的一套基于注解的數據校驗規范,目前已經從JSR 303的1.0版本升級到JSR 349的1.1版本,再到JSR 380的2.0版本(2.0完成于2017.08),已經經歷了三個版本 。在SpringBoot中已經集成在 starter-web中,所以無需在添加其他依賴。

SpringBoot如何優雅的處理校驗參數的方法

注解介紹

validator內置注解

注解

詳細信息

@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)

被注釋的元素必須符合指定的正則表達式

Hibernate Validator 附加的 constraint

注解

詳細信息

@Email

被注釋的元素必須是電子郵箱地址

@Length

被注釋的字符串的大小必須在指定的范圍內

@NotEmpty

被注釋的字符串的必須非空

@Range

被注釋的元素必須在合適的范圍內

@NotBlank

驗證字符串非null,且長度必須大于0

注意:

  • @NotNull 適用于任何類型被注解的元素必須不能與NULL
  • @NotEmpty 適用于String Map或者數組不能為Null且長度必須大于0
  • @NotBlank 只能用于String上面 不能為null,調用trim()后,長度必須大于0

使用

使用起來也非常簡單,下面略過創建項目

模擬用戶注冊封裝了一個UserDTO

當提交數據的時候如果使用以前的做法就是IF ELSE判斷參數使用validator則是需要增加注解即可。

例如非空校驗:

SpringBoot如何優雅的處理校驗參數的方法

然后需要在controller方法體添加@Validated不加@Validated校驗會不起作用

然后請求一下請求接口,把Email參數設置為空

參數:

{
  "userName":"luomengsun",
  "mobileNo":"11111111111",
  "sex":1,
  "age":21,
  "email":""
}

返回結果:

SpringBoot如何優雅的處理校驗參數的方法

后臺拋出異常

SpringBoot如何優雅的處理校驗參數的方法

這樣是能校驗成功,但是有個問題就是返回參數并不理想,前端也并不容易處理返回參數,所以我們添加一下全局異常處理,然后添加一下全局統一返回參數這樣比較規范。

添加全局異常

創建一個GlobalExceptionHandler類,在類上方添加@RestControllerAdvice注解然后添加以下代碼:

  /**
   * 方法參數校驗
   */
@ExceptionHandler(MethodArgumentNotValidException.class)
public ReturnVO handleMethodArgumentNotValidException(MethodArgumentNotValidException e) {
    log.error(e.getMessage(), e);
    return new ReturnVO().error(e.getBindingResult().getFieldError().getDefaultMessage());
  }

此方法主要捕捉MethodArgumentNotValidException異常然后對異常結果進行封裝,如果需要在自行添加其他異常處理。

添加完之后我們在看一下運行結果,調用接口返回:

{
  "code": "9999",
  "desc": "郵箱不能為空",
  "data": null
}

OK 已經對異常進行處理。

校驗格式

如果想要校驗郵箱格式或者手機號的話也非常簡單。

校驗郵箱

  /**
   * 郵箱
   */
  @NotBlank(message = "郵箱不能為空")
  @NotNull(message = "郵箱不能為空")
  @Email(message = "郵箱格式錯誤")
  private String email;

使用正則校驗手機號

校驗手機號使用正則進行校驗,然后限制了一下位數

  /**
   * 手機號
   */
  @NotNull(message = "手機號不能為空")
  @NotBlank(message = "手機號不能為空")
  @Pattern(regexp ="^[1][3,4,5,6,7,8,9][0-9]{9}$", message = "手機號格式有誤")
  @Max(value = 11,message = "手機號只能為{max}位")
  @Min(value = 11,message = "手機號只能為{min}位")
  private String mobileNo;

查看一下運行結果

傳入參數:

{
  "userName":"luomengsun",
  "mobileNo":"111111a",
  "sex":1,
  "age":21,
  "email":"1212121"
}

返回結果:

{
  "code": "9999",
  "desc": "郵箱格式錯誤",
  "data": null
}

這里不再驗證手機號的例子

自定義注解

上面的注解只有這么多,如果有特殊校驗的參數我們可以使用Validator自定義注解進行校驗

首先創建一個IdCard注解類

@Documented
@Target({ElementType.PARAMETER, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = IdCardValidator.class)
public @interface IdCard {

  String message() default "身份證號碼不合法";

  Class<?>[] groups() default {};

  Class<? extends Payload>[] payload() default {};

}

在UserDTO中添加@IdCard注解即可驗證,在運行時觸發,本文不對自定義注解做過多的解釋,下篇文章介紹自定義注解

  • message 提示信息
  • groups 分組
  • payload 針對于Bean

然后添加IdCardValidator 主要進行驗證邏輯

上面調用了is18ByteIdCardComplex方法,傳入參數就是手機號,驗證身份證規則自行百度

然后使用

  @NotNull(message = "身份證號不能為空")
  @IdCard(message = "身份證不合法")
  private String IdCardNumber;

分組

就比如上面我們定義的UserDTO中的參數如果要服用的話怎么辦?

在重新定義一個類然后里面的參數要重新添加注解?

Validator提供了分組方法完美了解決DTO服用問題

現在我們注冊的接口修改一下規則,只有用戶名不能為空其他參數都不進行校驗

先創建分組的接口

public interface Create extends Default {
}

我們只需要在注解加入分組參數即可例如:

 

 /**
   * 用戶名
   */
  @NotBlank(message = "用戶姓名不能為空",groups = Create.class)
  @NotNull(message = "用戶姓名不能為空",groups = Create.class)
  private String userName;

  @NotBlank(message = "郵箱不能為空",groups = Update.class)
  @NotNull(message = "郵箱不能為空",groups = Update.class)
  @Email(message = "郵箱格式錯誤",groups = Update.class)
  private String email;

然后在修改Controller在@Validated中傳入Create.class

  @PostMapping("/user")
  public ReturnVO userRegistra(@RequestBody @Validated(Create.class) UserDTO userDTO){
    ReturnVO returnVO = userService.userRegistra(userDTO);
    return returnVO ;
  }

然后調用傳入參數:

{
  "userName":"",
}

返回參數:

{
  "code": "9999",
  "desc": "用戶姓名不能為空",
  "data": null
}

OK 現在只對Create的進行校驗,而Updata組的不校驗,如果需要復用DTO的話可以使用分組校驗

校驗單個參數

在開發的時候一定遇到過單個參數的情況,在參數前面加上注解即可

  @PostMapping("/get")
  public ReturnVO getUserInfo(@RequestParam("userId") @NotNull(message = "用戶ID不能為空") String userId){
    return new ReturnVO().success();
  }

然后在Controller類上面增加@Validated注解,注意不是增加在參數前面。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

金乡县| 松溪县| 九寨沟县| 平武县| 南江县| 灵武市| 秦安县| 万荣县| 佳木斯市| 密山市| 乌拉特后旗| 峡江县| 巫溪县| 新建县| 馆陶县| 六安市| 土默特左旗| 内黄县| 门头沟区| 汪清县| 富平县| 丰台区| 华阴市| 来凤县| 桃江县| 邢台市| 东兰县| 拉萨市| 左云县| 宁海县| 志丹县| 措美县| 徐汇区| 会昌县| 吉首市| 宜良县| 肥西县| 苍山县| 萍乡市| 怀柔区| 永仁县|