Heim  >  Artikel  >  Java  >  So verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementieren

So verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementieren

WBOY
WBOYnach vorne
2023-05-11 17:49:19763Durchsuche

Information

Gruppensequenz @GroupSequenceProvider, @GroupSequence steuert die Datenüberprüfungssequenz und löst das Problem der gemeinsamen Logiküberprüfung mit mehreren Feldern.

Hibernate Validator bietet nicht standardmäßige @GroupSequenceProvider注解。针对当前对象实例的状态,动态来决定加载那些校验组进入默认校验组。
需要借助Hibernate Validation提供给我们的DefaultGroupSequenceProvider接口Um zu handhaben, unter welchen Umständen diese Attribute in die angegebene Gruppe gelangen .

1. Frühzeitige Vorbereitung

⏹Beachten Sie, dass der benutzerdefinierte Überprüfungswert nicht leer sein darf

@Documented
@Target({ ElementType.FIELD })
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = {ValidateIntegerNotEmpty.StrictIntegerNotEmptyValidator.class})
@ReportAsSingleViolation
public @interface ValidateIntegerNotEmpty {

    String msgArgs() default "";

	String message() default "{1001E}";

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

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

	class StrictIntegerNotEmptyValidator implements ConstraintValidator<ValidateIntegerNotEmpty, Integer> {

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

            return !ObjectUtils.isEmpty(value);
        }
    }
}

2. Wenn der Bewertungsstatus 2 ist (manuelle vorläufige Ablehnung), ist der Ablehnungsgrund der Bewertung

Erforderlich Füllen Sie die Elemente aus
    , der Bereich liegt zwischen 1 und 4
  • Wenn der Überprüfungsstatus nicht 2 ist (in Prüfung oder manuelle vorläufige Überprüfung bestanden), lautet der Grund für die Ablehnung der Bewertung

    Nicht erforderliche Elemente
  • ⏹Rezeption

    <!DOCTYPE html>
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
    <head>
        <script type="text/javascript" th:src="@{/js/public/jquery-3.6.0.min.js}"></script>
        <script type="text/javascript" th:src="@{/js/common/common.js}"></script>
        <title>test7页面</title>
    </head>
    <body>
    
        <button id="btn">校验数据</button>
    
        <h2>我是test7的页面</h2>
    </body>
    <script>
        $("#btn").click(() => {
    
            const param1 = {
            	// 人工初审拒绝
                auditStatus: 2,
                // 拒绝的原因
                auditRejectReason: 5,
            };
    
            const url = `http://localhost:8080/test7/groupSequenceProvider`;
            doAjax(url, param1, function(data) {
                console.log(data);
            });
        });
    </script>
    </html>
  • ⏹Zu verifizierendes Formular1
import com.example.jmw.common.validation.ValidateIntegerNotEmpty;
import com.example.jmw.form.validation.ValidateTest7FormProvider;
import lombok.Data;
import org.hibernate.validator.constraints.Range;
import org.hibernate.validator.group.GroupSequenceProvider;

@Data
// 通过该注解所对应的自定义Provider来实现多属性联合校验
@GroupSequenceProvider(ValidateTest7FormProvider.class)
public class Test7Form {

    /**
     * 1: 审核中
     * 2: 人工初审拒绝
     * 3: 人工初审通过
     */
    @ValidateIntegerNotEmpty(msgArgs = "审核状态类型")
    @Range(min = 1, max = 3, message = "审核拒绝原因:参数传递错误")
    private Integer auditStatus;

    /**
     * 1: 不符合准入要求
     * 2: 三方数据拒贷
     * 3: 授信额度为0
     * 4: 其他
     */
    @ValidateIntegerNotEmpty(msgArgs = "审核拒绝原因", groups = auditGroup.class)
    @Range(min = 1, max = 4, message = "审核拒绝原因:参数传递错误", groups = auditGroup.class)
    private Integer auditRejectReason;
	
	// 自定义分组
    public interface auditGroup {
    }
}

⏹Validator

import com.example.jmw.form.Test7Form;
import org.hibernate.validator.spi.group.DefaultGroupSequenceProvider;
import org.springframework.util.ObjectUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Optional;

public class ValidateTest7FormProvider implements DefaultGroupSequenceProvider<Test7Form> {

    @Override
    public List<Class<?>> getValidationGroups(Test7Form test7Form) {

        List<Class<?>> defaultGroupSequence = new ArrayList<>();
        defaultGroupSequence.add(Test7Form.class);

        if (ObjectUtils.isEmpty(test7Form)) {
            return defaultGroupSequence;
        }

        // 获取 人工初审 状态
        Integer auditStatus = Optional.ofNullable(test7Form.getAuditStatus()).orElse(0) ;

        // 如果 人工初审通过的话,审核拒绝原因的auditGroup组就会起作用,就变为必填项目,否则为选填项目
        if (auditStatus == 2) {
            defaultGroupSequence.add(Test7Form.auditGroup.class);
        }

        return defaultGroupSequence;
    }
}

⏹Controller-Ebene zur Verifizierung

@Controller
@RequestMapping("/test7")
public class Test7Controller {

    @Resource
    private LocalValidatorFactoryBean validator;

    @GetMapping("/init")
    public ModelAndView init() {

        ModelAndView modelAndView = new ModelAndView();
        modelAndView.setViewName("test7");
        return  modelAndView;
    }

    @PostMapping("/groupSequenceProvider")
    @ResponseBody
    public void groupSequenceProvider(@RequestBody Test7Form form) {

        Set<ConstraintViolation<Test7Form>> validate = validator.validate(form);
        for (ConstraintViolation<Test7Form> bean : validate) {

            // 获取当前的校验信息
            String message = bean.getMessage();
            System.out.println(message);
        }
    }
}

Wenn der Parameter auditStatus 2 ist (manuelle Ablehnung der Erstprüfung), überschreitet auditRejectReason (Audit-Ablehnungsgrund) 1 bis 4-Bereich, sodass die Verifizierungsinformationen angezeigt werden auditStatus ist Wenn es 3 ist (manuelle vorläufige Überprüfung bestanden), ist auditRejectReason (Audit-Ablehnungsgrund) nicht erforderlich, daher gibt es keine Informationen zum Überprüfungsfehler

Drei Anforderungen

So verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementieren

2 Wenn Besucher (1) besuchen, Es gibt höchstens 2 Berechtigungen

So verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementieren

Wenn der Leiter (2) zugreift, gibt es bis zu 4 Berechtigungen

So verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementierenWenn der Administrator (3) zugreift, gibt es bis zu 10 Berechtigungen

    ⏹Rezeption
  • <!DOCTYPE html>
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
    <head>
        <script type="text/javascript" th:src="@{/js/public/jquery-3.6.0.min.js}"></script>
        <script type="text/javascript" th:src="@{/js/common/common.js}"></script>
        <title>test7页面</title>
    </head>
    <body>
    
        <button id="btn">校验数据</button>
    
        <h2>我是test7的页面</h2>
    </body>
    <script>
        $("#btn").click(() => {
    
            const param2 = {
            	// 领导(2)访问
                role: 2,
                // 权限的数量为5
                permissionList: [1, 1, 1, 1, 1],
            };
    
            const url = `http://localhost:8080/test7/groupSequenceProvider`;
            doAjax(url, param2, function(data) {
                console.log(data);
            });
        });
    </script>
    </html>

    ⏹Steht für Schule Das verifizierte Formular2

    import com.example.jmw.common.validation.ValidateIntegerNotEmpty;
    import com.example.jmw.form.validation.ValidateTest7Form1Provider;
    import lombok.Data;
    import org.hibernate.validator.constraints.Range;
    import org.hibernate.validator.group.GroupSequenceProvider;
    
    import javax.validation.constraints.Size;
    import java.util.List;
    
    @Data
    // 通过该注解所对应的自定义Provider来实现多属性联合校验
    @GroupSequenceProvider(ValidateTest7Form1Provider.class)
    public class Test7Form1 {
    
        /**
         * 1: 访客
         * 2: 领导
         * 3: 管理员
         */
        @ValidateIntegerNotEmpty(msgArgs = "角色类型")
        @Range(min = 1, max = 3, message = "错误原因:参数传递错误")
        private Integer role;
    
        @Size.List({
                // 访客1个权限
                @Size(min = 1, max = 2, message = "访客最多拥有2个权限", groups = GuestGroup.class),
                // 领导4个权限
                @Size(min = 1, max = 4, message = "领导最多拥有4个权限", groups = LeaderGroup.class),
                // 管理员10个权限
                @Size(min = 1, max = 10, message = "管理员最多拥有10个权限", groups = AdminGroup.class)
        })
        private List<Integer> permissionList;
        
        // 游客分组
        public interface GuestGroup {
        }
        
        // 领导分组
        public interface LeaderGroup {
        }
        
        // 管理员分组
        public interface AdminGroup {
        }
    }
  • ⏹Validator
  • import com.example.jmw.form.Test7Form1;
    import org.hibernate.validator.spi.group.DefaultGroupSequenceProvider;
    import org.springframework.util.ObjectUtils;
    
    import java.util.*;
    
    public class ValidateTest7Form1Provider implements DefaultGroupSequenceProvider<Test7Form1> {
    
        /**
         * 1: 访客
         * 2: 领导
         * 3: 管理员
         */
        private final static List<Integer> roleList = Arrays.asList(1, 2, 3);
    
        @Override
        public List<Class<?>> getValidationGroups(Test7Form1 test7Form1) {
    
            List<Class<?>> defaultGroupSequence = new ArrayList<>();
            defaultGroupSequence.add(Test7Form1.class);
    
            if (ObjectUtils.isEmpty(test7Form1)) {
                return defaultGroupSequence;
            }
    
            // 获取角色code
            Integer role = Optional.ofNullable(test7Form1.getRole()).orElse(0) ;
            if (!roleList.contains(role)) {
                return defaultGroupSequence;
            }
    
            // 根据角色code,开启相应的组校验
            if (role == 1) {
                defaultGroupSequence.add(Test7Form1.GuestGroup.class);
            } else if (role == 2) {
                defaultGroupSequence.add(Test7Form1.LeaderGroup.class);
            } else if (role == 3) {
                defaultGroupSequence.add(Test7Form1.AdminGroup.class);
            }
    
            return defaultGroupSequence;
        }
    }

    ⏹Controller-Ebene führt Verifizierung durch

    @Controller
    @RequestMapping("/test7")
    public class Test7Controller {
    
        @Resource
        private LocalValidatorFactoryBean validator;
    
        @GetMapping("/init")
        public ModelAndView init() {
    
            ModelAndView modelAndView = new ModelAndView();
            modelAndView.setViewName("test7");
            return  modelAndView;
        }
    
        @PostMapping("/groupSequenceProvider")
        @ResponseBody
        public void groupSequenceProvider(@RequestBody Test7Form1 form) {
    
            Set<ConstraintViolation<Test7Form1>> validate = validator.validate(form);
            for (ConstraintViolation<Test7Form1> bean : validate) {
    
                // 获取当前的校验信息
                String message = bean.getMessage();
                System.out.println(message);
            }
        }
    }
  • Wenn die Rolle 2 (Leiter) ist, können höchstens 4 Berechtigungen vorhanden sein, sodass die Verifizierungsinformationen angezeigt werden
Wenn die Rolle 1 (Gast) ist, gibt es höchstens 2 Berechtigungen, sodass die Verifizierungsinformationen angezeigt werden.

Wenn die Rolle 3 (Administrator) ist, gibt es höchstens 10 Berechtigungen, also dort Es liegen keine Verifizierungsinformationen vor

Das obige ist der detaillierte Inhalt vonSo verwenden Sie die SpringBoot-Annotation @GroupSequenceProvider, um die gemeinsame Überprüfung mehrerer Bean-Attribute zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen