广州网站开发哪家公司好,世界十大网络公司排名,下35cm,如何查网站的百度快照讲故事前几天看公司一个新项目使用了FluentValidation#xff0c;大家都知道FluentValidation是一个非常强大的用于构建强类型验证规则的 .NET 框架#xff0c;帮程序员解决了繁琐的校验问题#xff0c;用起来非常爽#xff0c;但我还是遇到了一件非常不爽的事情,如下代码所… 讲故事前几天看公司一个新项目使用了FluentValidation大家都知道FluentValidation是一个非常强大的用于构建强类型验证规则的 .NET 框架帮程序员解决了繁琐的校验问题用起来非常爽但我还是遇到了一件非常不爽的事情,如下代码所示public class UserInformationValidator : AbstractValidatorUserInformation{public UserInformationValidator(){RuleFor(o o.UserName).Length(2, 20).WithMessage(姓名长度输入错误);RuleFor(o o.Sex).Must(oo男||o女).WithMessage(性别输入错误);RuleFor(o o.Age).ExclusiveBetween(0, 200).WithMessage(年龄输入错误);RuleFor(o o.Email).EmailAddress().WithMessage(邮箱输入错误);}}static void Main(string[] args){UserInformation userInformation new UserInformation();userInformation.UserName ;userInformation.Sex 女;userInformation.Age 2200;userInformation.Email xxxxx;UserInformationValidator validationRules new UserInformationValidator();var result validationRules.Validate(userInformation);if (!result.IsValid){Console.WriteLine( string.Join(Environment.NewLine, result.Errors.Select(x x.ErrorMessage).ToArray()));}}我们每验证一个对象,就要新建一个类型的验证器 如上的UserInformationValidator 虽然这样写逻辑上没有任何问题但我有洁癖哈接下来我们试着封装一下嘿嘿用更少的代码做更多的事情。安装在创建任何验证器之前您需要在项目中添加对 FluentValidation.dll 的引用。最简单的方法是使用 NuGet 包管理器或 dotnet CLI。模板化代码封装探索将模板化的代码提取到父类中仔细看上面的代码你会发现我们每新建一个验证器就必须要创建一个继承自AbstractValidator的类其中T是您希望验证的类的类型封装一个验证器父类public class CommonVaildatorT : AbstractValidatorT
{}增加验证规则真正的业务逻辑是写在UserInformationValidator验证器里面的而这块代码中只需要拿到RuleFor即可其它的统一封装到父类中对不对我们按照这个思路代码封装一个长度验证器规则。首先让我们看看RuleFor的原型public IRuleBuilderInitialT, TProperty RuleForTProperty(ExpressionFuncT, TProperty expression)它的参数是一个Func委托那么Expression是什么呢Experssion是一种表达式树表达式树是一种允许将lambda表达式表示为树状数据结构而不是可执行逻辑的代码。在C#中是Expression来定义的它是一种语法树或者说是一种数据结构。其主要用于存储需要计算、运算的一种结构它只提供存储功能不进行运算。通常Expression是配合Lambda一起使用这里就不做过多的解释了那么我们就能很轻易的封装出长度验证器规则了public void LengthVaildator(ExpressionFuncT, string expression, int min, int max, string Message){RuleFor(expression).Length(min, max).WithMessage(Message);}同理我们也可以接着封装谓词验证器规则 邮箱验证器规则等等public void MustVaildator(ExpressionFuncT, string expression ,FuncT,string, bool expression2, string Message){RuleFor(expression).Must(expression2).WithMessage(Message);}public void EmailAddressVaildator(ExpressionFuncT, string expression, string Message){RuleFor(expression).EmailAddress().WithMessage(Message);}封装验证方法上面我们把验证器封装好了那么将 var result validationRules.Validate(userInformation);这种验证方法封装一下不是手到擒来,代码如下public static string ModelValidatorT(T source, AbstractValidatorT sourceValidator) where T : class{var results sourceValidator.Validate(source);if (!results.IsValid)return string.Join(Environment.NewLine, results.Errors.Select(x x.ErrorMessage).ToArray());elsereturn ;}测试封装后的代码CommonVaildatorUserInformation commonUserInformation new CommonVaildatorUserInformation();commonUserInformation.LengthVaildator(o o.UserName, 2, 30, 姓名长度输入错误);commonUserInformation.MustVaildator(o o.Sex, (user, _) user.Sex 男||user.Sex女 , 性别输入错误);commonUserInformation.ExclusiveBetweenVaildator(oo.Age,0, 200, 年龄输入错误);commonUserInformation.EmailAddressVaildator(o o.Email, 邮箱输入错误);string msg VaildatorHelper.ModelValidator(userInformation, commonUserInformation);Console.WriteLine(msg);这样代码看起来是不是就简洁多了我这里就只封装了四种验证规则其它的我就不在此封装了。总结文章来源于工作中的点点滴滴这也是我的即兴封装大家要是有更好的封装代码欢迎交流独乐乐不如众乐乐本篇就说到这里啦希望对您有帮助。