Springboot usa JSR303 para verificar los parámetros enviados, incluida la verificación de grupo y la verificación personalizada

Estructura de directorio para verificación de parámetros:
Inserte la descripción de la imagen aquí

1. Si queremos verificar los parámetros entrantes, solo necesitamos usar anotaciones en la clase de entidad pasada por el front-end receptor.

/**
 * 品牌
 *
 * @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. Verificación de grupo:
agregue la interfaz de agrupación AddGroup, no es necesario escribir nada en ella.

public interface AddGroup {
    
    
}

Agregue la interfaz de grupo UpdateGroup, no es necesario escribir nada en ella.

public interface UpdateGroup {
    
    
}

El campo brandId no necesita pasar este parámetro al agregar datos, pero debe pasarse al modificarlo.
Luego agregue una anotación
@Validated ({AddGroup.class} al nuevo método del controlador correspondiente

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

Agregue una anotación
@Validated ({UpdateGroup.class} al método de modificación del controlador correspondiente

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

3. Verificación personalizada:
tome @ListValue (vals = {0,1}
private Integer showStatus sobre el campo showStatus como ejemplo.
1. Escriba una anotación de verificación personalizada
2. Escriba un validador personalizado ConstraintValidator
3. Asocie un validador personalizado y un anotación de validación


Agregar dependencia de maven

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

Escribe una anotación de verificación personalizada

@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 {
    
     };
}

Escribir un validador personalizado 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);
    }
}

Supongo que te gusta

Origin blog.csdn.net/u014496893/article/details/113728850
Recomendado
Clasificación