All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.moon.validator.annotation.AllInLongs Maven / Gradle / Ivy

package com.moon.validator.annotation;

import com.moon.validator.impl.AllInLongsValidator;

import javax.validation.Constraint;
import javax.validation.Payload;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * @author moonsky
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.PARAMETER})
@Constraint(validatedBy = AllInLongsValidator.class)
public @interface AllInLongs {

    /**
     * 数据项是否允许为 null 值,只验证集合或数组里的数据项是否可为 null
     * 

* 如果要验证集合/数组字段本身是否可为 null、empty 请用{@link NotNull}、{@link NotEmpty} * * @return 等于 false 时不可包含 null 数据项 */ boolean nullable() default true; /** * long 值列表,多个值用逗号隔开 * * @return long 值,如:"1, 2, 3, 4, 5";间隔符之间的空格会自动忽略 */ String values() default ""; /** * 错误消息提示模板 * * @return {@link Message#AT_ALL} */ String message() default Message.AT_ALL; /** * 分组验证 * * @return 分组对不同场景下使用不同的验证规则 */ Class[] groups() default {}; Class[] payload() default {}; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy