首页 > 其他分享 >EasyExcel validator校验 及自定义 枚举校验

EasyExcel validator校验 及自定义 枚举校验

时间:2023-06-30 16:22:57浏览次数:36  
标签:return String 自定义 EasyExcel 校验 private import message public

需要校验的实体

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.ruoyi.system.domain.enums.RoleStatusEnum;
import com.ruoyi.system.domain.enums.YesOrNoEnum;
import com.ruoyi.system.domain.export.BaseExportData;
import com.ruoyi.system.domain.vo.role.SysRoleVO;
import com.ruoyi.system.service.imports.valid.EnumValid;
import org.hibernate.validator.constraints.Range;

import javax.validation.constraints.NotBlank;
import javax.validation.constraints.Size;

/**
 * 角色导出数据类
 * @author ruoyi
 **/
public class RoleExcelData extends BaseExportData {

    @NotBlank(message = "不可空")
    @Range(min = 1, message = "应为正整数且小于19位")
    @ColumnWidth(20)
    @ExcelProperty("角色ID")
    private String roleId;

    @Size(max = 30, message = "不大于30位字符")
    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("角色名称")
    private String roleName;

    @Size(max = 100, message = "不大于100位字符")
    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("权限字符")
    private String roleKey;

    @NotBlank(message = "不可空")
    @Range(min = 0, max = 9999, message = "不大于9999自然数")
    @ColumnWidth(20)
    @ExcelProperty("角色排序")
    private String roleSort;

    @NotBlank(message = "不可空")
    @EnumValid(value = YesOrNoEnum.class, method2 = "getName", message = "值不正确,[是, 否, 1, 0]中的一个值")
    @ColumnWidth(20)
    @ExcelProperty("控制台权限")
    private String unimisFlag;

    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("数据权限")
    private String dataScope;

    @NotBlank(message = "不可空")
    @EnumValid(value = RoleStatusEnum.class, method2 = "getName", message = "值不正确,[正常, 停用, 0, 1]中的一个值")
    @ColumnWidth(20)
    @ExcelProperty("角色状态")
    private String status;

    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("应用ID")
    private String appId;

    @EnumValid(value = YesOrNoEnum.class, method2 = "getName", message = "值不正确,[是, 否, 1, 0]中的一个值")
    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("默认角色标志")
    private String defaultFlag;

    @EnumValid(value = YesOrNoEnum.class, method2 = "getName", message = "值不正确,[是, 否, 1, 0]中的一个值")
    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("用户授权使用")
    private String allowBindingUser;

    @EnumValid(value = YesOrNoEnum.class, method2 = "getName", message = "值不正确,[是, 否, 1, 0]中的一个值")
    @NotBlank(message = "不可空")
    @ColumnWidth(20)
    @ExcelProperty("角色组授权使用")
    private String allowBindingRoleGroup;

    @ColumnWidth(30)
    @ExcelProperty("字段级权限备注")
    private String filedPermsRemark;

    @ExcelProperty("错误描述")
    private String error;

    @ExcelIgnore
    private SysRoleVO vo;

    public String getRoleId() {
        return roleId;
    }

    public void setRoleId(String roleId) {
        this.roleId = roleId;
    }

    public String getRoleName() {
        return roleName;
    }

    public void setRoleName(String roleName) {
        this.roleName = roleName;
    }

    public String getRoleKey() {
        return roleKey;
    }

    public void setRoleKey(String roleKey) {
        this.roleKey = roleKey;
    }

    public String getRoleSort() {
        return roleSort;
    }

    public void setRoleSort(String roleSort) {
        this.roleSort = roleSort;
    }

    public String getUnimisFlag() {
        return unimisFlag;
    }

    public void setUnimisFlag(String unimisFlag) {
        this.unimisFlag = unimisFlag;
    }

    public String getDataScope() {
        return dataScope;
    }

    public void setDataScope(String dataScope) {
        this.dataScope = dataScope;
    }

    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }

    public String getAppId() {
        return appId;
    }

    public void setAppId(String appId) {
        this.appId = appId;
    }

    public String getDefaultFlag() {
        return defaultFlag;
    }

    public void setDefaultFlag(String defaultFlag) {
        this.defaultFlag = defaultFlag;
    }

    public String getAllowBindingUser() {
        return allowBindingUser;
    }

    public void setAllowBindingUser(String allowBindingUser) {
        this.allowBindingUser = allowBindingUser;
    }

    public String getAllowBindingRoleGroup() {
        return allowBindingRoleGroup;
    }

    public void setAllowBindingRoleGroup(String allowBindingRoleGroup) {
        this.allowBindingRoleGroup = allowBindingRoleGroup;
    }

    public String getFiledPermsRemark() {
        return filedPermsRemark;
    }

    public void setFiledPermsRemark(String filedPermsRemark) {
        this.filedPermsRemark = filedPermsRemark;
    }

    public String getError() {
        return error;
    }

    public void setError(String error) {
        this.error = error;
    }

    public SysRoleVO getVo() {
        return vo;
    }

    public void setVo(SysRoleVO vo) {
        this.vo = vo;
    }
}

调用位置

for (int i = 0; i < excelData.size(); i++) {
    RoleExcelData row = excelData.get(i);
    String errorMsg = EasyExcelValidHelper.validateEntity(row);
    row.setError(errorMsg);
}

枚举注解

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

/**
 * @description :校验枚举注解
 */
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.METHOD})
@Constraint(validatedBy = EnumValidator.class)
public @interface EnumValid {
    /**
     * 枚举的类型
     */
    Class<?> value();

    /**
     * 错误消息
     *
     * @return
     */
    String message() default "枚举类型的值不正确";

    /**
     * 获取枚举值的方法
     */
    String method() default "getCode";

    String method2() default "";

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

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

枚举具体验证类

import com.ruoyi.common.core.utils.bean.BeanUtils;
import org.apache.commons.compress.utils.Lists;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.List;

/**
 * @description :枚举验证
 */
public class EnumValidator implements ConstraintValidator<EnumValid, Object> {

    private static final Logger logger = LoggerFactory.getLogger(EnumValidator.class);

    /**
     * 存具体枚举的值
     */
    private final List<Object> values = Lists.newArrayList();

    @Override
    public void initialize(EnumValid constraintAnnotation) {

        Class<?> enumClazz = constraintAnnotation.value();
        Object[] enumConstants = enumClazz.getEnumConstants();
        if (null == enumConstants) {
            return;
        }
        Method method = BeanUtils.findMethod(enumClazz, constraintAnnotation.method());
        if (null == method) {
            logger.warn("枚举对象:[{}]中不存在方法:[{}],请检查.", enumClazz.getName(), constraintAnnotation.method());
            throw new RuntimeException("枚举对象中不存在获取值的方法");
        }

        method.setAccessible(true);
        try {
            for (Object enumConstant : enumConstants) {
                values.add(method.invoke(enumConstant));
            }
        } catch (IllegalAccessException | InvocationTargetException e) {
            logger.warn("获取枚举类:[{}]的枚举对象的值失败.", enumClazz);
            throw new RuntimeException("获取枚举值失败");
        }

        Method method2 = BeanUtils.findMethod(enumClazz, constraintAnnotation.method2());
        if (null != method2) {
            try {
                for (Object enumConstant : enumConstants) {
                    values.add(method2.invoke(enumConstant));
                }
            } catch (IllegalAccessException | InvocationTargetException e) {
                logger.warn("获取枚举类:[{}]的枚举对象的值失败.", enumClazz);
                throw new RuntimeException("获取枚举值失败");
            }
        }
    }

    @Override
    public boolean isValid(Object value, ConstraintValidatorContext context) {
        return null == value || values.contains(value);
    }
}

校验工具类

import com.alibaba.excel.annotation.ExcelProperty;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.groups.Default;
import java.lang.reflect.Field;
import java.util.Set;

/**
 * @description :校验工具
 */
public class EasyExcelValidHelper {

    private static final Logger logger = LoggerFactory.getLogger(EasyExcelValidHelper.class);

    private EasyExcelValidHelper() {
    }

    /**
     * 校验常量
     */
    private static final Validator VALIDATOR = Validation.buildDefaultValidatorFactory().getValidator();

    /**
     * description 对象校验
     *
     * @param entity 导入数据
     * @return java.lang.String
     **/
    public static <T> String validateEntity(T entity) {
        StringBuilder result = null;
        try {
            result = new StringBuilder();
            Set<ConstraintViolation<T>> set = VALIDATOR.validate(entity, Default.class);
            if (set != null && !set.isEmpty()) {
                for (ConstraintViolation<T> cv : set) {
                    Field declaredField = entity.getClass().getDeclaredField(cv.getPropertyPath().toString());
                    ExcelProperty annotation = declaredField.getAnnotation(ExcelProperty.class);
                    result.append(annotation.value()[0]).append(cv.getMessage()).append("; ");
                }
            }
        } catch (NoSuchFieldException e) {
            logger.error("参数验证异常", e);
        }
        return result.toString();
    }
}

标签:return,String,自定义,EasyExcel,校验,private,import,message,public
From: https://www.cnblogs.com/stubborn-dude/p/17517114.html

相关文章

  • Kubernetes编程—— 使用自定义资源 —— 介绍自定义资源(Custom Resource,CR)
    介绍自定义资源(CustomResource,CR)自定义资源(CustomResource,CR),它是整个Kubernetes生态系统中最核心的扩展机制。 定义资源可以用作系统内部使用的对象,仅仅对它进行声明式定义,而不关联控制器逻辑,用不保存少量配置信息。但是自定义资源也可以成为很多复杂Kubernetes项目的......
  • ASP.NET的自定义分页
    usingSystem;usingSystem.Web.UI;usingSystem.Web.UI.WebControls;usingSystem.ComponentModel;usingSystem.Data;usingSystem.Data.SqlClient;namespaceControlLibs{///<summary>///CustomPager的摘要说明。///</summary>[DefaultProperty(&......
  • 前端实现radio+其它自定义输入选项
    后端数据库设计:1.类型字段  2.用户输入的其它信息记录字段 前端:<el-form-itemlabel="性能要求类型">     <el-radio-groupv-model="form.performanceRequirementType">      <el-radio       v-for="dictinperformanceRequire......
  • 数据对象校验原理
    表单数据校验jquery-validationThejQueryValidationPluginprovidesdrop-invalidationforyourexistingforms,whilemakingallkindsofcustomizationstofityourapplicationreallyeasy.来自jquery-validation项目。大概就是提供嵌入式的方式去校验表单,灵活......
  • 自定义 make 脚本扩展 artisan make 命令
    有时候,我们想自定义生成php类文件,于是自己写了一个,能兼容去调用artisanmake命令。文件名就叫make 放在与artisan相同目录下,命令:phpmake--help代码如下:#!/usr/bin/envphp<?phpif($argv[1]=='--help'||empty($argv[1])){echo'phpmake<type><filenam......
  • elecrton 自定义关闭事件
     main.jsconst{app,BrowserWindow,Menu,ipcMain}=require('electron')constmainWindow=newBrowserWindow({webPreferences:{contextIsolation:false//必须有,不然报错}})//执行关闭自定义关闭ipcMain.on('handelClose'......
  • 前端Vue自定义简单通用省市区选择器picker地区选择器picker 收获地址界面模版
    前端Vue自定义简单通用省市区选择器picker地区选择器picker收获地址界面模版,下载完整代码请访问uni-app插件市场地址:https://ext.dcloud.net.cn/plugin?id=13266效果图如下:代码实现如下:cc-selectDity使用方法<!--省市区选择show:是否显示 @sureSelectArea:确认事件......
  • el-tree需要自定义双击事件触发选择节点
    单击事件onclick="xxxx"双击事件ondblclick="xxxx"<el-tree:data="data"@node-click="handleNodeClick"></el-tree>data(){return{numTime:0,}},methods:{//自定义双击事件handleNodeClick(......
  • 面向对象之魔术方法(内置方法),反射,异常之自定义异常
    魔术方法(内置方法)(面试题)#类里面内置的双下划线开头的一些方法,他们具有特殊的功能,我们称之为是魔术方法,简称魔法比如:__init__"""魔术方法的学习只需要掌握每个方法什么时候触发或者执行"""1.__str__,__repr__方法#__str__,__repr__方法classStudent():def_......
  • springboot 自定义异常 全局异常处理器
    创建自定义异常类,继承 RuntimeException类1publicclassCustomExceptionextendsRuntimeException{2publicCustomException(Stringmessage){3super(message);4}5}在指定情况下抛出该异常,代码如下: @ServicepublicclassCategoryServiceIm......