Java对象数据校验工具类VerifyUtils

Wesley13
• 阅读 1151

背景介绍

Excel数据导入是很常见的功能,可很多时候客户导入的数据未必能入库,比如字段超长,类型错误……等。在产品经理提出要做数据校验的时候你难道要一个字段一个字段去校验?而且系统有几十张表都需要类似的功能,更何况客户导入的数据成千上万条数据,如果每次提示某个字段错误肯定是不友好的。要求是提示excel某行某些字段发生了什么错误。

网络上找了许久没有找到能方便灵活控制错误信息,和我们系统符合的工具,索性自己写一个用吧。废话不多说,利用注解完成相应数据校验。

1.注解类

import java.lang.annotation.*;

/**
 * @author 郏高阳
 * @date 2020/9/2
 * @jdk.version 1.8
 * @desc javaBean校验注解
 */
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface Verify {

    /**
     * 字段名称
     * @return
     */
    String name() default "";

    /**
     * 最大长度 0不校验大于0才生效
     * @return
     */
    int maxLength() default 0;

    /**
     * 必填
     * @return
     */
    boolean required() default false;

    /**
     * 是否包含特殊字符
     * @return
     */
    boolean specialCharacters() default false;

    /**
     * 数字验证
     * @return
     */
    boolean number() default false;

    /**
     * 正则
     * @return
     */
    Regexp regexp() default @Regexp();
}

/**
 * @author 郏高阳
 * @date 2020/9/2
 * @jdk.version 1.8
 * @desc 用于校验正则注解类
 */
public @interface Regexp {
    String regexp() default "";
    String message() default "";
}

2.校验工具类

import cn.hutool.core.util.NumberUtil;
import cn.hutool.core.util.ReUtil;
import cn.hutool.core.util.ReflectUtil;
import org.apache.commons.lang3.StringUtils;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;

/**
 * @author 郏高阳
 * @Type VerifyUtils.java
 * @date 2020/9/2
 * @jdk.version 1.8
 * @desc javaBean校验工具类
 */

//@Verify(maxLength = 10, required = true, number = true)
//private String f32;
//@Verify(regexp = @Regexp(regexp = "\\w+[\u4E00-\u9FFF]+\\d+", message = "正则不匹配"), specialCharacters = true)
//private String f33;

public class VerifyUtils {

    /**
     * 校验对象
     *
     * @param obj 对象
     * @return 错误信息
     */
    public static List<String> verify(Object obj) {
        List<String> stringList = new ArrayList<>();
        Field[] fields = obj.getClass().getDeclaredFields();
        for (Field f : fields) {
            if (f.isAnnotationPresent(Verify.class)) {
                StringBuilder stringBuilder = new StringBuilder();
                Verify verify = f.getAnnotation(Verify.class);
                Object object = ReflectUtil.getFieldValue(obj, f.getName());
                String value = null;
                if (object != null) value = object.toString();

                if (verify.required()) {
                    if (StringUtils.isBlank(value)) {
                        stringBuilder.append("字段不能为空|");
                    }
                }

                if (StringUtils.isNotBlank(value)) {
                    if (verify.specialCharacters()) {
                        if (value.contains("|") || value.contains("'") || value.indexOf('"') > -1) {
                            stringBuilder.append("包含非法字符|");
                        }
                        if (value.length() != value.trim().length()) {
                            stringBuilder.append("前后不能包含空格|");
                        }
                    }
                    if (verify.maxLength() > 0) {
                        if (value.length() > verify.maxLength()) {
                            stringBuilder.append("内容长度超长|");
                        }
                    }
                    if (verify.number()) {
                        if (!NumberUtil.isNumber(value)) {
                            stringBuilder.append("不是数字类型|");
                        }
                    }
                    Regexp regexp = verify.regexp();
                    if (StringUtils.isNotBlank(regexp.regexp())) {
                        boolean isMatch = ReUtil.isMatch(regexp.regexp(), value);
                        if (!isMatch) {
                            stringBuilder.append(regexp.message()).append("|");
                        }
                    }
                }
                if (StringUtils.isNotBlank(stringBuilder.toString())) {
                    String name = verify.name();
                    if (StringUtils.isBlank(name)) {
                        name = f.getName();
                    }
                    String message = name + ":" + stringBuilder.substring(0, stringBuilder.toString().length() - 1);
                    stringList.add(message);
                }
            }
        }
        return stringList;
    }
}

3.测试

目前只做了非空,类型,长度,特殊字符,目前实现的仅仅是为了符合公司业务需要,有需要可自行修改完善

Java对象数据校验工具类VerifyUtils

Java对象数据校验工具类VerifyUtils

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
3年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Stella981 Stella981
3年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
ThinkPHP 根据关联数据查询 hasWhere 的使用实例
很多时候,模型关联后需要根据关联的模型做查询。场景:广告表(ad),广告类型表(ad\_type),现在需要筛选出广告类型表中id字段为1且广告表中status为1的列表先看关联的设置部分 publicfunctionadType(){return$thisbelongsTo('A
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这