快速校验非法字符工具

基于hibernate validator实现快速校验非法字符提示工具

非空校验注解器

IfNotNullRegex.java
/**
 * 如果不为空的拦截验证
 */
@Target({
    ElementType.FIELD })
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = IfNotNullRegexConstraintValidator.class)
public @interface IfNotNullRegex {
   

    /**
     * 默认错误文案
     * @return
     */
    String message() default "非法参数";

    /**
     * 不为空场景下的正则
     * @return
     */
    String[] regex();

    /**
     * 匹配结果为 matcher类型 显示对客文案
     * @return
     */
    boolean[] matcher();

    /**
     * 正则提示的对客文案
     * @return
     */
    String[] regexMsg() default "";

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

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

}

自定义非空校验注解实现

IfNotNullRegexConstraintValidator.java
import com.google.common.collect.Lists;
import org.hibernate.validator.engine.ConstraintValidatorContextImpl;
import org.hibernate.validator.engine.PathImpl;
import org.springframework.util.ReflectionUtils;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.lang.reflect.Field;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * 如果不为空注解参数实现
 */
public class IfNotNullRegexConstraintValidator implements
                                              ConstraintValidator<IfNotNullRegex, String> {
   

    /**
     * 正则表达式
     */
    private String[]  regex;

    /**
     * 正则表达式匹配期望结果
     */
    private boolean[] matcher;

    /**
     * 表达式对应的文案
     */
    private String[]  msg;

    /**
     * 合法字符校验器
     */
    private LegalCharValidBuilder.LegalCharValid legalCharValid = LegalCharValidBuilder.instance().build();

    @Override
    public void initialize(IfNotNullRegex ifNotNull) {
   
        regex = ifNotNull.regex();
        msg = ifNotNull.regexMsg();
        matcher = ifNotNull.matcher();
        Assert.isTrue(regex.length == ifNotNull.matcher().length, "参数非法");
        // 填充正则消息
        if (regex.length != ifNotNull.regexMsg().length) {
   
            msg = new String[regex.length];
            fillErrorMsg(ifNotNull.regexMsg(), ifNotNull.message());
        }
    }

    @Override
    public boolean isValid(String str, ConstraintValidatorContext constraintValidatorContext) {
   
        if (StringUtil.isEmpty(str)) {
   
            return true;
        }
        boolean flag;
        // 错误消息集合
        List<String> errMsgList = Lists.newArrayList();
        for (int i = 0; i < regex.length; i++) {
   
            flag = str.matches(regex[i]);
            // 如果符合期望匹配就抛出异常
            flag = (flag == matcher[i
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
checksum校验码生成工具是一种用于验证数据完整性的工具。它通过对数据进行计算,生成一个校验码,并将校验码附加在数据中。当数据接收方收到数据时,可以通过再次计算校验码,并与接收到的校验码进行比较,从而判断数据是否发生了损坏或被篡改。 checksum校验码生成工具的工作原理是将数据分割成固定大小的数据块,然后对每个数据块进行计算。通常使用的校验算法是循环冗余校验(CRC)或校验和算法。这些算法通过对数据进行位运算和异或运算等操作,生成一个校验码。 要使用checksum校验码生成工具,首先需要将需要进行校验的数据输入到工具中。然后选择合适的校验算法和参数,并开始计算校验码。一旦计算完成,校验码将会被自动附加到原始数据中。 使用checksum校验码生成工具可以有效地检测数据传输过程中是否发生了错误。当数据在传输过程中经过噪声、干扰或传输错误的环境时,仅依靠数据本身的内容很难判断数据是否完整和正确。而通过校验码的比对,可以快速、准确地识别出数据是否受到了损坏或篡改。 总之,checksum校验码生成工具是一种用于验证数据完整性的工具,它通过对数据进行计算,生成一个校验码,并将校验码附加在数据中。使用该工具可以迅速、准确地检测数据是否发生了错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值