流畅的验证组件:FluentValidation

简介:

       这里要介绍一款与企业库VAB(Validation Application Block),ASP.NET MVC基于Attribute声明式验证所不同的验证组件,FluentValidation,其利用表达式语法链式编程,使得验证组件与实体分开。我喜欢他的原因是喜欢表达式,喜欢链式的感觉,大有一气呵成之意。

    进入今天的主题首先如果你还没有这款组件,你可以利用VS2010的NuGet安装,(如果不会的请安装上篇开源DataBase组件:FluentMigrator中提到的方式安装),命令为:

未命名

 

  现在我们可以开始体验了,实体类do任然是上节的Orders:

do:

复制代码
public   class  Orders 
   { 
        public  int ID {  getset; } 

        public  string CustomerID {  getset; } 

        public  decimal DisCount {  getset; } 

        public DateTime OrderDate {  getset; } 
   }
复制代码

 

验证逻辑:

复制代码
public   class  OrdersValidator:AbstractValidator<Orders> 
    { 
         public  OrdersValidator() 
        { 
            RuleFor(orders => orders.CustomerID).NotEmpty().Length( 220).WithName( " CustomerID "); 
            RuleFor(orders => orders.DisCount).GreaterThanOrEqualTo( 0).LessThan( 1).WithMessage( " discount must between 0 and 1! "); 
            RuleFor(orders => orders.OrderDate.Date).GreaterThanOrEqualTo(DateTime.Now.Date).WithName( " Order Date "); 
        } 
    }
复制代码

看见这样的代码你的感觉如何?现在式的语言讲究的不仅在于功能,还有语义。

下面我们来写个简单的测试类测试它:

复制代码
[TestMethod] 
        public  void TestMethod1() 
       { 
            var orders =  new Orders(){DisCount =  2,CustomerID =  " 1 ", OrderDate = DateTime.Now.AddDays(- 1).Date}; 
           IValidator validator =  new OrdersValidator(); 
            var results = validator.Validate(orders); 

            var validationSucceeded = results.IsValid; 
            var failures = results.Errors; 
           Assert.IsTrue(failures.Any(t => t.PropertyName ==  " CustomerID ")); 
           Assert.IsTrue(failures.Any(t => t.PropertyName ==  " DisCount ")); 
           Assert.IsTrue(failures.Any(t => t.PropertyName ==  " OrderDate.Date ")); 
           failures.ToList().ForEach(t=>Debug.WriteLine(t.ErrorMessage)); 
       }
复制代码

    

结果:

验证结果

单元测试结果就不贴了,觉得多余。

   最后忘说了这款组件为我们提供了很多语言的多语言支持:

     我在思考对于架构设计中我们采用的验证组件可以任意切换,我们完全可以为VAB,FluentValidation同一抽象接口做个门面模式。在借助于IOC插入式架构,利用不同的key,获取验证组件接口,而这个key值我将会处理在方法的Attribute上,AOP方式横切于我们的应用程序,验证本来就是个业务功能组件,横切点。我也是正在如此引用我的架构。


作者:破  狼 
出处:http://www.cnblogs.com/whitewolf/ 
本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。该文章也同时发布在我的独立博客中-个人独立博客博客园--破狼51CTO--破狼。http://www.cnblogs.com/whitewolf/archive/2012/05/27/2520593.html


相关文章
|
4月前
|
前端开发
三种方式实现主题切换方案
三种方式实现主题切换方案
|
6月前
|
缓存 网络协议 数据挖掘
如何使用弱网环境来验证游戏中的一些延迟问题
如何使用弱网环境来验证游戏中的一些延迟问题
|
7月前
|
缓存 前端开发 Cloud Native
《PWA实战:如何为你的网站增加离线功能和推送通知》
《PWA实战:如何为你的网站增加离线功能和推送通知》
129 0
|
9月前
|
编解码 前端开发 JavaScript
响应式图像优化:如何根据用户设备和网络条件优化网页中的图像,以提高用户体验和加载速度。
响应式图像优化:如何根据用户设备和网络条件优化网页中的图像,以提高用户体验和加载速度。
|
10月前
|
前端开发 JavaScript UED
优化前端打字动画和输入交互
在现代前端开发中,优化用户体验是至关重要的一环。当涉及到用户输入和动画时,打字动画和输入交互是常见的需求。本文将重点探讨如何优化前端打字动画和输入交互,使用户感受到更加流畅和自然的体验。
101 0
|
12月前
|
移动开发 JSON API
h5调起原生分享面板,展示更多功能方案
h5调起原生分享面板,展示更多功能方案
196 0
|
缓存 小程序 JavaScript
【微信小程序】收藏功能的实现(条件渲染、交互反馈)
wxml页面部分比较简单,添加一个view容器,命名为tool。然后添加三个小view,分别表示点赞、评论、收藏。每个小view中包括图片和数量,即image和text标签。每个功能按钮都绑定了对应的点击事件,即catchtap属性。除此之外,每个功能按钮绑定当前文章的id号。
371 0
|
自然语言处理 JavaScript 前端开发
动态滑动图片验证码组件(支持多语言,移动端)
动态滑动图片验证码组件(支持多语言,移动端)
动态滑动图片验证码组件(支持多语言,移动端)
|
弹性计算 数据安全/隐私保护 对象存储
云渲染管理系统使用演示 | 学习笔记
快速学习云渲染管理系统使用演示
102 0
|
数据采集 JavaScript UED
一个简易的预渲染自动骨架屏方案
一个简易的预渲染自动骨架屏方案
728 0
一个简易的预渲染自动骨架屏方案