相关文章推荐
没有腹肌的墨镜  ·  Element: <oj-select-one>·  3 月前    · 
腹黑的鸡蛋面  ·  python ...·  10 月前    · 
欢乐的篮球  ·  从ROS到AGV调度 - 知乎·  1 年前    · 
package com.peterpyx.myutilpro.util.validation;
import org.apache.commons.lang3.ObjectUtils;
import org.springframework.beans.BeanWrapper;
import org.springframework.beans.BeanWrapperImpl;
import javax.validation.Constraint;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import javax.validation.Payload;
import java.lang.annotation.*;
import java.util.Date;
 * @author cr 2020-04-21 校验结束时间大于等于开始时间
@Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.ANNOTATION_TYPE,
        ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = CheckTimeInterval.CheckTimeIntervalValidation.class)
@Documented
@Repeatable(CheckTimeInterval.List.class)
public @interface CheckTimeInterval {
    String[] beginTime() default {"beginTime"};
    String[] endTime() default {"endTime"};
    String message() default "开始时间不能大于结束时间 ";
    Class<?>[] groups() default {};
    Class<? extends Payload>[] payload() default {};
    @Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER,
            ElementType.ANNOTATION_TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    @interface List {
        CheckTimeInterval[] value();
    class CheckTimeIntervalValidation implements ConstraintValidator<CheckTimeInterval, Object> {
        private String[] beginTime;
        private String[] endTime;
        @Override
        public void initialize(CheckTimeInterval constraintAnnotation) {
            this.beginTime = constraintAnnotation.beginTime();
            this.endTime = constraintAnnotation.endTime();
        @Override
        public boolean isValid(Object value, ConstraintValidatorContext context) {
            BeanWrapper beanWrapper = new BeanWrapperImpl(value);
            boolean valid = true;
            for (int i = 0; i < beginTime.length; i++) {
                String s = beginTime[i];
                Object propertyValue = beanWrapper.getPropertyValue(s);
                Object propertyValue1 = beanWrapper.getPropertyValue(endTime[i]);
                if (ObjectUtils.isNotEmpty(propertyValue) && ObjectUtils.isNotEmpty(propertyValue1)) {
                    Date beginTimeVal = (Date) propertyValue;
                    Date endTimeVal = (Date) propertyValue1;
                    int result = endTimeVal.compareTo(beginTimeVal);
                    if (result < 0) {
                        valid = false;
                        break;
            return valid;
@Data
@CheckTimeInterval(beginTime = {"beginTime","start"},endTime = {"endTime","end"})
public class TEST{
    @ApiModelProperty("身份证号码")
    @NotBlank(message = "身份证号码不为空")
    private String idcard;
    private Date beginTime;
    private Date endTime;
    private Date start;
    private Date end;
                    代码package com.peterpyx.myutilpro.util.validation;import org.apache.commons.lang3.ObjectUtils;import org.springframework.beans.BeanWrapper;import org.springframework.beans.BeanWrapperImpl;import javax.validation.Constraint;import javax.validation.
				
import javax.validation.Constraint; import javax.validation.Payload; import java.lang.annotation.*; * @author cr 2020-04-21 校验结束时间大于等于开始时间 @Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.ANNOT.
在日常开发中常常会出现接口参数中有开始时间结束时间两个属性,需要校验两个时间的大小关系,但JSR-303并未给出这样的注解,但是给出了ConstraintValidator这个接口,提供用户的自定义校验。下面开始开始时间结束时间校验的注解。 1 时间校验注解 这个注解只能应用于类上,通过startTime和endTime方法指定被注解的类的开始时间结束时间的属性名。 @Target({Ele...
var m = param.getMonth() + 1; var d = param.getDate(); var startDate = y + '-' + (m < 10 ? ('0' + m) : m) + '-'+ (d < 10 ? ('0' + d) : d); var endDa. import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream;
Springboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdfSpringboot SpringMVC thymeleaf页面提交Validation实现实例.pdf
写 api 就不可避免的需要校验字段,一般我们就是 if 走天下,遇到不同接口,校验相同的字段也是 cv 大法;方便是方便了,但是代码显得很臃肿,不优雅,后期维护的时候得看半天才能理出来;那有没有办法避免这种情况,试试 Hibernate Validator 吧。 spring-boot 版本2.3之后貌似取消了 spring-boot-starter-web 里面的 hibernate-validator 依赖,高版本需要自己添加一下, 完整依赖如下: <dependencies>.
在实际项目中有些参数的校验SpringBoot提供的校验注解不足以满足我们的需求,这时候就需要自己写检验注解。 这里我们以检验接口请求中两个时间参数为例子,假定有一个接口 @PostMapping(value="/test") String test(@Validated@Request Request request); Request请求体里有3个Date类型参数startDate和endDate @Getter @Setter
实际项目中经常需要对传入的日期时间进行判断,如是否为一年内,几个月之内,几天前,几天之内等等的需求。如要求前端传入的日期是要为当前日期一年内的某个日期,基于jdk8的LocalDateTime or LocalDate等常用的做法如下: // 前端传字符串如‘2020-07-13 09:09:09’ springmvc接收并转换为LocalDateTime类型 @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH
https://blog.csdn.net/f641385712/article/details/82468927 https://blog.csdn.net/f641385712/article/details/82469877 https://blog.csdn.net/u012240455/article/details/79014224
### 回答1: Spring Boot 支持使用 JSR-303 Bean Validation 规范来验证请求参数。可以在 Controller 的方法参数上使用 @Valid 注解来验证对应的请求参数。如果验证失败,会抛出 MethodArgumentNotValidException 异常。 ### 回答2: Spring Boot Validation 是 Spring 框架中的一个注解驱动的类库,它实现了对数据的校验功能。通过使用 Spring Boot Validation 可以很方便地进行表单数据验证,从而减少代码的复杂度和错误率。 Spring Boot Validation 主要依靠注解来进行数据的校验,常用的注解包括: @NotNull:验证值不为 null。 @NotEmpty:验证字符串不为空。 @NotBlank:验证字符串不为空白。 @Min:验证数字大小。 @Max:验证数字大小。 @Size:验证字符串或集合长度。 @Valid:表示需要递归验证。 Spring Boot Validation 支持的校验类型十分丰富,可以对 Java 基本数据类型和常见的容器类型进行校验,同时也能自定义校验器验证数据的正确性。 Spring Boot Validation 的应用场景很广泛,主要适用于前后端交互的表单数据处理,可以有效减少非法输入的发生,优化用户体验。另外,在企业级应用中使用 Spring Boot Validation 还可以提高系统的稳定性和安全性,避免因为数据错误导致的系统崩溃或者数据泄露。 总之,Spring Boot Validation 可以使开发人员更加方便地进行数据校验,减少了开发工作量,同时也可以提高系统的效率和安全性。 ### 回答3: Spring Boot是一个全新的框架,它可以简化Spring应用程序的构建和部署。一个典型的Spring Boot应用程序包括许多表单和输入字段,因此数据验证和处理是非常重要的。Spring Boot框架提供了一个称为Validation的表单验证核心组件,因此我们可以很容易地验证用户输入并检查数据的准确性。 Spring Boot中的Validation可以检查输入以确保其满足应用程序的特定要求,并提供与规则不符合的错误消息。这可以帮助我们提高应用程序的健壮性和安全性,并有效地防止恶意用户提交不正确的数据。Validation的基本原则是检查输入是否有效,然后返回相关的错误消息。Spring Boot提供了许多常见的Validation规则,如非空、整数、正数、电子邮件格式等等,并且还允许我们自定义验证规则。通过使用Spring Boot的Validation,我们可以使表单验证更加简单和方便。 在Spring Boot中使用Validation并不复杂,我们只需要在提交表单的控制器中添加@Valid注解,同时将要验证的表单数据传递给BindingResult对象。如果表单数据不符合验证规则,Validation将会自动生成错误消息和细节,并存储在BindingResult对象中。这使得我们可以轻松地通过将错误消息返回到用户界面来提供错误反馈信息。 总而言之,Spring Boot的Validation可以有效地帮助我们创建健壮、安全、正确的应用程序,并使表单验证更加简单和方便。通过使用验证和自定义规则,我们可以确保用户输入的准确性,并最大限度地降低应用程序错误的可能性。因此,对于任何需要表单处理和验证的Spring Boot应用程序,Validation都是一项非常关键的技术。