真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

SpringBoot使用hibernatevalidator校驗(yàn)

本文將全面的介紹如何使用 validator 進(jìn)行數(shù)據(jù)校驗(yàn)

站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到東蘭網(wǎng)站設(shè)計(jì)與東蘭網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請(qǐng)、網(wǎng)站空間、企業(yè)郵箱。業(yè)務(wù)覆蓋東蘭地區(qū)。

本文源碼: https://gitee.com/yintianwen7/taven-springboot-learning/tree/master/springboot-validate

準(zhǔn)備工作

我們只需要引入 spring-boot-starter-web 包即可使用

1.常用注解

SpringBoot 使用hibernate validator校驗(yàn)

常用注解

2.簡(jiǎn)單的實(shí)體校驗(yàn)

public class CardDTO {

  @NotBlank
  private String cardId;

  @Size(min = 10, max = 10)
  @NotNull
  private String cardNum; // 卡號(hào)

  @Past
  @NotNull
  private Date createDate;

  @Range(max = 3)
  private String cardType;

  // 省略get set
}
@RestController
public class UserController {

  @PostMapping("simple")
  public Object simple(@RequestBody @Valid CardDTO cardDTO) {
    return cardDTO;
  }

}
  • 實(shí)體屬性上添加校驗(yàn)注解
  • controller 方法 參數(shù)前 使用@Valid 即可

3. 復(fù)雜的實(shí)體校驗(yàn)

 3.1 嵌套實(shí)體校驗(yàn)

public class UserDTO {

  @NotBlank
  private String userId;

  @NotBlank
  private String username;

  private String password;

  @Valid
  private List cardList;

  //省略 get set
}

controller 寫(xiě)法 同上,只是在 UserDTO cardList 屬性上標(biāo)記@Valid 注解 即可。 3.2 List 校驗(yàn)

SpringBoot 使用hibernate validator校驗(yàn)

無(wú)效示例

如果我們想校驗(yàn) 一個(gè)實(shí)體List,如上圖所示的這種寫(xiě)法是完全不起效的。

我們需要像 嵌套校驗(yàn)時(shí)一樣,對(duì) List 做一層封裝

public class ValidList implements List {

  @Valid
  private List list = new ArrayList<>();

  public List getList() {
    return list;
  }

  public void setList(List list) {
    this.list = list;
  }

  // 省略了 實(shí)現(xiàn)方法
}

重寫(xiě)實(shí)現(xiàn)方法完全使用 this.list.xxx()

Gitee:spring 會(huì)將數(shù)據(jù)封裝到我們定義的 list 屬性中,又將屬性聲明了 @Valid 使得 hibernate validator 可以為我們做校驗(yàn)!

3.3 使用 @Validated 分組校驗(yàn)

public interface Insert {
}

public interface Update {
}

定義兩個(gè)接口

public class GroupCardDTO {

  @NotBlank(groups = {Update.class})
  private String id;

  @NotBlank(groups = {Insert.class})
  private String cardNum;

  @NotNull(groups = {Insert.class, Update.class})
  private Integer cardType;

  //省略 get set
}

實(shí)體標(biāo)記的注解中添加 group 屬性

@PostMapping("insert_card")
  public Object insert_card(@RequestBody @Validated(Insert.class) GroupCardDTO card){
    return card;
  }

使用 @Validated(xxx.class) 標(biāo)記參數(shù),完成分組校驗(yàn)!

4.自定義注解校驗(yàn)

當(dāng) validator 提供的注解無(wú)法滿足我們的業(yè)務(wù)需求,可以通過(guò)自定義的方式來(lái)實(shí)現(xiàn)校驗(yàn)。

需求:校驗(yàn)?zāi)匙址仨殲榇髮?xiě)或者小寫(xiě)

public enum CaseMode {
  UPPER,
  LOWER
}

定義一個(gè)枚舉類

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

@Target( { ElementType.FIELD })
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = CheckCaseValidator.class)
@Documented
public @interface CheckCase {

  String message() default "";

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

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

  CaseMode value() default CaseMode.LOWER;

}
  • 定義注解
  • @Constraint 指定我們的校驗(yàn)邏輯實(shí)現(xiàn)類
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;

public class CheckCaseValidator implements ConstraintValidator {

  private CaseMode caseMode;

  @Override
  public void initialize(CheckCase constraintAnnotation) {
    this.caseMode = constraintAnnotation.value();
  }

  @Override
  public boolean isValid(String value, ConstraintValidatorContext context) {

    if (value == null || "".equals(value.trim())) {
      return false;
    }

    switch (this.caseMode) {
      case LOWER:
        return value.equals(value.toLowerCase());
      case UPPER:
        return value.equals(value.toUpperCase());
      default:
        return false;
    }

  }

}
  • initialize() 初始化時(shí)執(zhí)行,可以用來(lái)獲取注解中的屬性
  • isValid() 實(shí)現(xiàn)我們的校驗(yàn)邏輯

備注

我們自定義的注解依然支持 @Validated group 分組

本節(jié)源碼: https://gitee.com/yintianwen7/taven-springboot-learning/tree/master/springboot-validate

本地下載地址:springboot-validate_jb51.rar

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


分享標(biāo)題:SpringBoot使用hibernatevalidator校驗(yàn)
URL網(wǎng)址:http://weahome.cn/article/jpegih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部