Rookey.Frame之实体表单验证
昨天给大家介绍了实体FluentValidation验证,今天继续给大家介绍表单验证,在Rookey.Frame框架中,表单验证有PrimaryKeyFields字段验证、唯一验证、必填验证、常用验证及自定义验证,PrimaryKeyFields字段验证昨天也略微介绍了下PrimaryKeyFields对记录唯一性进行验证,也即是由定义的一个或多个字段唯一确定一条记录,保存时不允许重复,根据定义的,就是在实体表定义时在[ModuleConfig]实体类属性标记中定义,也可以在模块管理界面修改
针对唯一性验证,可以在实体类属性字段标记[FieldConfig(IsUnique = true, IsRequired = true)]中定义,也可以在表单管理中修改
必填验证同理。
针对常用验证功能只能在表单中配置,打开表单管理在表单字段中修改验证类型:
目前支持的常用验证类型见如下枚举定义:
- /// <summary>
- /// 验证类型
- /// </summary>
- public enum ValidateTypeEnum
- {
- /// <summary>
- /// 无
- /// </summary>
- [Description("无")]
- No = ,
- /// <summary>
- /// Eamil
- /// </summary>
- [Description("邮箱")]
- email = ,
- /// <summary>
- /// URL
- /// </summary>
- [Description("网址")]
- url = ,
- /// <summary>
- /// 整型
- /// </summary>
- [Description("整型")]
- intNum = ,
- /// <summary>
- /// 浮点型
- /// </summary>
- [Description("浮点型")]
- floatNum = ,
- /// <summary>
- /// 手机号码
- /// </summary>
- [Description("手机")]
- mobile = ,
- /// <summary>
- /// </summary>
- [Description("QQ")]
- qq = ,
- /// <summary>
- /// 邮政编码
- /// </summary>
- [Description("邮政编码")]
- zip = ,
- /// <summary>
- /// 电话号码
- /// </summary>
- [Description("电话")]
- phone = ,
- /// <summary>
- /// 传真
- /// </summary>
- [Description("传真")]
- faxno = ,
- /// <summary>
- /// 身份证
- /// </summary>
- [Description("身份证")]
- idCard =
- }
针对自身项目需要也可以将其他验证添加到其中
另外表单验证中针对数值型还可以设置最大最小值验证,针对字段串字段可以设置最大最小字符长度验证,同样在在表单字段中设置
表单验证代码如下:
- /// <summary>
- /// 表单字段配置验证
- /// </summary>
- /// <param name="moduleId">模块Id</param>
- /// <param name="model">实体对象</param>
- /// <param name="verifyFields">需要验证字段的字段集合</param>
- /// <returns></returns>
- public static string FormFieldVerify(Guid moduleId, object model, List<string> verifyFields)
- {
- Type modelType = GetModelType(moduleId);
- PropertyInfo idProperty = modelType.GetProperty("Id");
- Guid id = idProperty.GetValue(model, null).ObjToGuid(); //当前记录Id
- //表单字段验证
- if (verifyFields != null && verifyFields.Count > )
- {
- foreach (string field in verifyFields)
- {
- PropertyInfo p = modelType.GetProperty(field);
- if (p == null) continue;
- object value = p.GetValue(model, null);
- Sys_FormField formField = SystemOperate.GetDefaultFormSingleField(moduleId, field);
- if (formField == null) continue;
- string fieldDisplay = SystemOperate.GetFieldDisplay(moduleId, field);
- #region 必填验证
- if (formField.IsRequired.HasValue && formField.IsRequired.Value) //必填验证
- {
- ControlTypeEnum crlType = formField.ControlTypeOfEnum;
- string requiredDes = crlType == ControlTypeEnum.ComboBox ||
- crlType == ControlTypeEnum.ComboGrid ||
- crlType == ControlTypeEnum.ComboTree ?
- "请选择" : "不能为空";
- bool isForeignField = SystemOperate.IsForeignField(moduleId, field); //是否是外键字段
- if (value == null || (isForeignField && value.ObjToGuid() == Guid.Empty))
- {
- return string.Format("【{0}】为必填字段,{1}!", fieldDisplay, requiredDes);
- }
- }
- if (formField.ControlTypeOfEnum == ControlTypeEnum.IntegerBox ||
- formField.ControlTypeOfEnum == ControlTypeEnum.NumberBox) //最大值、最小值验证
- {
- if (formField.MinValue.HasValue && value.ObjToDecimal() < formField.MinValue.Value ||
- formField.MaxValue.HasValue && value.ObjToDecimal() > formField.MaxValue.Value)
- {
- return string.Format("【{0}】的值介于【{1}】~【{2}】之间!", fieldDisplay, formField.MinValue.Value, formField.MaxValue.Value);
- }
- }
- if (p.PropertyType == typeof(String) && ((formField.MinCharLen.HasValue && formField.MinCharLen.Value > ) || (formField.MaxCharLen.HasValue && formField.MaxCharLen.Value > ))) //字符长度验证
- {
- if (value.ObjToStr().Length < formField.MinCharLen.Value ||
- value.ObjToStr().Length > formField.MaxCharLen.Value)
- {
- return string.Format("【{0}】字符长度在【{1}】~【{2}】之间!", fieldDisplay, formField.MinCharLen.Value, formField.MaxCharLen.Value);
- }
- }
- #endregion
- #region 基本验证
- if (formField.ValidateTypeOfEnum != ValidateTypeEnum.No && p.PropertyType == typeof(String))
- {
- //基本验证
- switch (formField.ValidateTypeOfEnum)
- {
- case ValidateTypeEnum.email:
- {
- bool rs = Validator.IsEmail(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的邮箱地址!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.idCard: //身份证验证
- {
- bool rs = Validator.IsIDCard(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的身份证号码!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.intNum:
- {
- bool rs = Validator.IsInteger(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,只能输入整数值!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.floatNum:
- {
- bool rs = Validator.IsNumber(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,只能输入数值!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.faxno:
- case ValidateTypeEnum.phone:
- {
- bool rs = Validator.IsTelePhoneNumber(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的固定电话号码!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.mobile:
- {
- bool rs = Validator.IsMobilePhoneNumber(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的手机号码!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.qq:
- {
- bool rs = Validator.IsIntegerPositive(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的QQ号码!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.url:
- {
- bool rs = Validator.IsURL(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的URL!", fieldDisplay);
- }
- break;
- case ValidateTypeEnum.zip:
- {
- bool rs = Validator.IsZipCode(value.ObjToStr());
- if (!rs) return string.Format("【{0}】字段值无效,请输入正确的邮编!", fieldDisplay);
- }
- break;
- }
- }
- #endregion
- #region 字段唯一性验证
- if (formField.IsUnique.HasValue && formField.IsUnique.Value) //唯一性验证
- {
- List<ConditionItem> conditonItems = new List<ConditionItem>() { new ConditionItem() { Field = field, Method = QueryMethod.Equal, Value = value } };
- if (id != Guid.Empty) //编辑时排除当前记录
- {
- conditonItems.Add(new ConditionItem() { Field = "Id", Method = QueryMethod.NotEqual, Value = id });
- }
- object exp = GetQueryCondition(moduleId, conditonItems);
- string errMsg = string.Empty;
- object tempModel = GetEntity(moduleId, exp, null, out errMsg);
- if (tempModel != null)
- {
- return string.Format("【{0}】=【{1}】的记录已存在,请不要重复添加!", fieldDisplay, SystemOperate.GetFieldDisplayValue(moduleId, model, formField));
- }
- }
- #endregion
- }
- }
- return string.Empty;
- }
针对自定义验证,框架提供了验证接口
- /// <summary>
- /// 操作处理接口
- /// </summary>
- /// <typeparam name="T"></typeparam>
- public interface IModelOperateHandle<T> where T : class
- {/// <summary>
- /// 单个实体操作前验证或处理,针对新增保存前、删除前、修改保存前
- /// </summary>
- /// <param name="operateType">操作类型</param>
- /// <param name="t">操作对象</param>
- /// <param name="errMsg">错误信息</param>
- /// <param name="otherParams">其他参数</param>
- /// <returns>是否通过验证</returns>
- bool BeforeOperateVerifyOrHandle(ModelRecordOperateType operateType, T t, out string errMsg, object[] otherParams = null);
/// <summary>- /// 多个实体操作前验证或处理,针对新增保存前、删除前、修改保存前
- /// </summary>
- /// <param name="operateType">操作类型</param>
- /// <param name="ts">操作对象集合</param>
- /// <param name="errMsg">错误信息</param>
- /// <param name="otherParams">其他参数</param>
- /// <returns>是否通过验证</returns>
- bool BeforeOperateVerifyOrHandles(ModelRecordOperateType operateType, List<T> ts, out string errMsg, object[] otherParams = null);
- #endregion
- }
例如针对工作流程删除验证:
- class Bpm_WorkFlowOperateHandle : IModelOperateHandle<Bpm_WorkFlow>
- {/// <summary>
- /// 操作前验证,如果流程已经在运行则不能删除
- /// </summary>
- /// <param name="operateType"></param>
- /// <param name="t"></param>
- /// <param name="errMsg"></param>
- /// <param name="otherParams"></param>
- /// <returns></returns>
- public bool BeforeOperateVerifyOrHandle(ModelRecordOperateType operateType, Bpm_WorkFlow t, out string errMsg, object[] otherParams = null)
- {
- errMsg = string.Empty;
- if (operateType == ModelRecordOperateType.Del)
- {
- //如果该流程存在流程实例则不允许删除
- Bpm_WorkFlowInstance workflowInst = CommonOperate.GetEntity<Bpm_WorkFlowInstance>(x => x.Bpm_WorkFlowId == t.Id, null, out errMsg);
- if (workflowInst != null)
- {
- errMsg = "运行中的流程不允许删除!";
- return false;
- }
- }
- return true;
- }
- /// <summary>
- /// 操作前验证
- /// </summary>
- /// <param name="operateType"></param>
- /// <param name="ts"></param>
- /// <param name="errMsg"></param>
- /// <param name="otherParams"></param>
- /// <returns></returns>
- public bool BeforeOperateVerifyOrHandles(ModelRecordOperateType operateType, List<Bpm_WorkFlow> ts, out string errMsg, object[] otherParams = null)
- {
- errMsg = string.Empty;
- if (operateType == ModelRecordOperateType.Del)
- {
- foreach (Bpm_WorkFlow t in ts)
- {
- //如果该流程存在流程实例则不允许删除
- Bpm_WorkFlowInstance workflowInst = CommonOperate.GetEntity<Bpm_WorkFlowInstance>(x => x.Bpm_WorkFlowId == t.Id, null, out errMsg);
- if (workflowInst != null)
- {
- errMsg += string.Format("【{0}】,", t.Name);
- }
- }
- if (errMsg.Length > )
- {
- errMsg = string.Format("流程{0}正在运行不允许删除!", errMsg);
- return false;
- }
- }
- return true;
- }
- }
OK,由于时间有限今天Rookey.Frame框架验证功能就介绍到此地,祝大家生活愉快!
Rookey.Frame之实体表单验证的更多相关文章
- 示例:WPF开发的简单ObjectProperyForm用来绑定实体表单
原文:示例:WPF开发的简单ObjectProperyForm用来绑定实体表单 一.目的:自定义控件,用来直接绑定实体数据,简化开发周期 二.实现: 1.绑定实体对象 2.通过特性显示属性名称 3.通 ...
- 从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件
一.摘要 本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案, 即使你会使用jQuery也能在阅读中发现些许秘籍. 本文是介绍两个最常用的jQuery插件. 分别用 ...
- Rookey.Frame之实体FluentValidation验证
昨天给大家介绍了Rookey.Frame框架的实体设计,今天继续跟大家分享实体的FluentValidation验证,在Rookey.Frame框架中可以设置多种验证方式:FluentValidati ...
- vue validate多表单验证思考 之前写过一个里外层,现在觉得不合适,应该平行的写,然后都给ret,最后判断ret 再做出反应,这样整体表单的所有验证就都报验证,然后最后提交的时候把组件内的对象合并到总的对象,再提交
vue validate多表单验证思考 之前写过一个里外层,现在觉得不合适,应该平行的写,然后都给ret,最后判断ret 再做出反应,这样整体表单的所有验证就都报验证,然后最后提交的时候把组件内的对象 ...
- Rookey.Frame企业级极速开发框架
项目详细介绍 Rookey.Frame是一套基于.NET MVC + easyui的企业级极速开发框架,支持简单逻辑模块零代码编程.支持工作流(BPM).支持二次开发,具有高扩展性.高复用性.高伸缩性 ...
- Rookey.Frame v1.0快速开发平台-整体介绍
Rookey.Frame v1.0是一套基于.NET MVC的极速开发框架,支持简单逻辑模块零代码编程.支持二次开发,具有高扩展性.高复用性.高伸缩性. 框架特点 (1)简单逻辑模块实现零代码编程,通 ...
- Rookey.Frame企业级快速开发框架开源了
Rookey.Frame是一套基于.NET MVC + easyui的企业级极速开发框架,支持简单逻辑模块零代码编程.支持工作流(BPM).支持二次开发,具有高扩展性.高复用性.高伸缩性:应广大网友要 ...
- Rookey.Frame v1.0极速开发平台稳定版发布
Rookey.Frame v1.0经过一年时间的修改及沉淀,稳定版终于问世了,此版本经过上线系统验证,各个功能点都经过终端用户验证并持续优化,主要优化以下几个方面: 1.性能较原来提升3倍之多 2.修 ...
- Rookey.Frame之DAL工厂
昨天给大家介绍了表单验证功能,今天给大家介绍下Rookey.Frame框架的数据层工厂,由于Rookey.Frame框架ORM是基于servicestack.ormlite,很多朋友反映这个网上中文资 ...
随机推荐
- [Spark]-Spark发展历程与基本概念
Hadoop十年 找了一张Hadoop十年的生态发展图: Spark概况: Apache Spark是一个开源簇运算框架,最初是由加州大学柏克莱分校AMPLab所开发.相对于Hadoop的MapRed ...
- springboot 日期转化报错
问题场景: 使用Springboot框架搭建服务,传日期参数json参数为2016-08-15 17:00:00这种格式,springboot中不能识别,将其转化为对象对应的日期属性.而是抛出异常信息 ...
- 用js获取客户端IP地址
<script src="http://pv.sohu.com/cityjson?ie=utf-8"></script> <script type=& ...
- Linux入门,这七大习惯得有!
对于很多Linux初学者来说,在刚开始使用Linux系统时会感到很多不适.这里为大家整理了自己以前Linux入门时别人告诉我的七个习惯.我相信如果你运用了这七个习惯,在你使用Linux时你会感觉更安全 ...
- UC手机浏览器(U3内核)相关文档整理
Note:绝大多数API在IOS版下不支持,使用前请自行测试. UC官方的开发者中心:http://www.uc.cn/business/developer.shtml U3内核定制<meta& ...
- 58、synchronized同步方法
线程安全问题 先看下面代码出现的问题: 定义一个Task类,里面有一个成员变量和一个有boolean类型参数的方法,方法内部会根据传入参数修改成员变量的值. package com.sutaoyu.T ...
- 使用TS+Sequelize实现更简洁的CRUD
如果是经常使用Node来做服务端开发的童鞋,肯定不可避免的会操作数据库,做一些增删改查(CRUD,Create Read Update Delete)的操作,如果是一些简单的操作,类似定时脚本什么的, ...
- macOS 安装 pcl 1.8.0
Mac 上的 pcl 一直有问题. 找不到 pcl_viewer 查看 pcd 文件.写个程序用 pcl::visualization::CloudViewer 查看点云,遇到 Runtime Exc ...
- local variables referenced from a Lambda expression must be final or effectively final------理解
前几天使用lamdba时,报了一个这个错,原因是在lamdba体中使用了一个变量,觉得很奇怪! 今天在读这本书的时候,又看到了这个解释,这里有了更深刻的理解,总结一下: 在jdk1.8之前在使用匿名内 ...
- 关于app的cpu占用率想到的几个问题
1.top 命令获取的cpu是手机瞬间的cpu 2.dumpsys获取的是一段时间cpu的平均值?那么这段时间是指哪段,从哪开始到什么时候结束? 3.如果想测试app某操作下的cpu占用情况时候.应该 ...