パラメータ検証用のディレクトリ構造:
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);
}
}