Springbootは、JSR303を使用して、グループ検証やカスタム検証など、送信されたパラメーターを検証します。

パラメータ検証用のディレクトリ構造:
ここに画像の説明を挿入

1.着信パラメータを確認する場合は、受信フロントエンドから渡されたエンティティクラスでアノテーションを使用するだけで済みます。

/**
 * 品牌
 *
 * @date 2019-10-01 21:08:49
 */
@Data
@TableName("pms_brand")
public class BrandEntity implements Serializable {
    
    
	private static final long serialVersionUID = 1L;

	/**
	 * 品牌id
	 */
	@NotNull(message = "修改必须指定品牌id",groups = {
    
    UpdateGroup.class})//只有在修改的时候才会触发
	@Null(message = "新增不能指定id",groups = {
    
    AddGroup.class})//只有在新增的时候才会触发
	@TableId
	private Long brandId;
	/**
	 * 品牌名
	 */
	@NotBlank(message = "品牌名必须提交",groups = {
    
    AddGroup.class,UpdateGroup.class})
	private String name;
	/**
	 * 品牌logo地址
	 */
	@NotBlank(groups = {
    
    AddGroup.class})
	@URL(message = "logo必须是一个合法的url地址",groups={
    
    AddGroup.class,UpdateGroup.class})
	private String logo;
	/**
	 * 介绍
	 */
	private String descript;
	/**
	 * 显示状态[0-不显示;1-显示]
	 */
//	@Pattern()
	@NotNull(groups = {
    
    AddGroup.class, UpdateStatusGroup.class})
  	@ListValue(vals={
    
    0,1},groups = {
    
    AddGroup.class, UpdateStatusGroup.class})
	private Integer showStatus;
	/**
	 * 检索首字母
	 */
	@NotEmpty(groups={
    
    AddGroup.class})
	@Pattern(regexp="^[a-zA-Z]$",message = "检索首字母必须是一个字母",groups={
    
    AddGroup.class,UpdateGroup.class})
	private String firstLetter;
	/**
	 * 排序
	 */
	@NotNull(groups={
    
    AddGroup.class})
	@Min(value = 0,message = "排序必须大于等于0",groups={
    
    AddGroup.class,UpdateGroup.class})
	private Integer sort;

}

2.グループ検証:
AddGroupグループ化インターフェイスを追加します。何も書き込む必要はありません。

public interface AddGroup {
    
    
}

UpdateGroupグループインターフェイスを追加します。何も書き込む必要はありません。

public interface UpdateGroup {
    
    
}

brandIdフィールドは、データを追加するときにこのパラメーターを渡す必要はありませんが、変更するときに渡す必要があります。
次に、対応するコントローラーの新しいメソッドにアノテーション
@Validated({AddGroup.class}を追加します

    /**
     * 保存
     */
    @RequestMapping("/save")
    public R save(@Validated({
    
    AddGroup.class}) @RequestBody BrandEntity brand) {
    
    
        brandService.save(brand);
        return R.ok();
    }

対応するコントローラーの変更メソッドにアノテーション
@Validated({UpdateGroup.class}を追加します

	/**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@Validated({
    
    UpdateGroup.class}) @RequestBody BrandEntity brand) {
    
    
        brandService.updateById(brand);
        return R.ok();
    }

3.カスタム検証:
として、フィールドshowStatusの上にある@ListValue(vals = {0,1}
プライベート整数showStatusを取り上げます。1
カスタム検証アノテーションを記述します。2
カスタムバリデーターConstraintValidatorを記述します。3
カスタムバリデーターとカスタムを関連付けます検証アノテーション


Mavenの依存関係を追加する

 <dependency>
     <groupId>javax.validation</groupId>
     <artifactId>validation-api</artifactId>
     <version>2.0.1.Final</version>
 </dependency>

カスタム検証アノテーションを作成する

@Documented
@Constraint(validatedBy = {
    
     ListValueConstraintValidator.class })//关联自定义的校验器
@Target({
    
     METHOD, FIELD, ANNOTATION_TYPE, CONSTRUCTOR, PARAMETER, TYPE_USE })
@Retention(RUNTIME)
public @interface ListValue {
    
    
    String message() default "{ListValue.message}";

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

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

    int[] vals() default {
    
     };
}

カスタムバリデーターを書くConstraintValidator

public class ListValueConstraintValidator implements ConstraintValidator<ListValue,Integer> {
    
    
    private Set<Integer> set = new HashSet<>();
    //初始化方法
    @Override
    public void initialize(ListValue constraintAnnotation) {
    
    
        int[] vals = constraintAnnotation.vals();
        for (int val : vals) {
    
    
            set.add(val);
        }
    }

    //判断是否校验成功
    /**
     *
     * @param value 需要校验的值
     * @param context
     * @return
     */
    @Override
    public boolean isValid(Integer value, ConstraintValidatorContext context) {
    
    
        return set.contains(value);
    }
}

おすすめ

転載: blog.csdn.net/u014496893/article/details/113728850