easypoi之IExcelVerifyHandler自定义校验使用

41 篇文章 0 订阅

 添加自定义校验规则需要继承IExcelVerifyHandler,然后给importParam设置这个校验器


@Component
public class AppImportVerify implements IExcelVerifyHandler<AutAppB> {

    @Autowired
    private IAutAppBService autAppBServiceImpl;

    @Override
    public ExcelVerifyHandlerResult verifyHandler(AutAppB autAppB) {
        ExcelVerifyHandlerResult result = new ExcelVerifyHandlerResult();
        //假设我们要添加用户,
        //现在去数据库查询loginName,如果存在则表示校验不通过。
        //假设现在数据库中有个loginName 1234560
        AutAppB byId = autAppBServiceImpl.getById(autAppB.getAppId().toString());
        if (byId!=null) {
            result.setMsg("唯一校验失败");
            result.setSuccess(false);
            return result;
        }
        result.setSuccess(true);
        return result;
    }
}

注意:如果使用spring的话,需要注入自定义的校验器,不能通过new


@Autowired
  private AppImportVerify appImportVerify;


            MultipartFile file2 = multipartRequest.getFile("file");
            ImportParams importParams = new ImportParams();
            //开启校验
            importParams.setNeedVerfiy(true);
            importParams.setHeadRows(1);
            //如果用spring,这里要注入
            importParams.setVerifyHandler(appImportVerify);

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
ElementPlus是一个基于Vue.js的UI库,提供了丰富的组件和功能。其中,ElementPlus还提供了自定义校验规则的功能。 使用ElementPlus自定义校验规则可以通过以下步骤实现: 1. 在组件中添加自定义校验规则。 ```vue <template> <el-form :model="form" :rules="rules" ref="form"> <el-form-item label="Email" prop="email"> <el-input v-model="form.email"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { form: { email: "" }, rules: { email: [ { required: true, message: "请输入邮箱", trigger: "blur" }, { validator: this.validateEmail, trigger: "blur" } ] } }; }, methods: { validateEmail(rule, value, callback) { if (!value) { callback(new Error("请输入邮箱")); } else { const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/; if (!emailReg.test(value)) { callback(new Error("请输入正确的邮箱")); } else { callback(); } } }, submitForm() { this.$refs.form.validate(valid => { if (valid) { // 校验通过,提交表单 console.log("表单数据:", this.form); } else { // 校验失败,提示错误信息 console.log("校验失败"); } }); } } }; </script> ``` 在上面的代码中,我们使用了`validator`属性来添加自定义校验规则,将`validateEmail`方法作为校验函数传递给`validator`属性。在`validateEmail`方法中,我们使用正则表达式来判断输入的邮箱格式是否正确,如果不正确则返回错误信息,否则返回校验通过的信号。 2. 在`validateEmail`方法中,我们使用了`callback`函数来返回校验结果。当校验结果为`false`时,我们需要传递一个错误信息给`callback`,否则直接调用`callback()`即可。 3. 在方法中,我们使用了`this.$refs.form.validate`来触发表单校验。该方法会返回一个布尔值,表示表单是否校验通过。如果校验通过,我们可以提交表单,否则需要提示错误信息。 总结: 使用ElementPlus自定义校验规则可以为我们提供更加灵活的校验方式,通过`validator`属性和`callback`函数可以实现自定义校验逻辑。同时,ElementPlus还提供了丰富的校验规则,可以满足我们大多数的校验需求。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值