流畅的验证组件:FluentValidation
?????? 這里要介紹一款與企業庫VAB(Validation Application Block),ASP.NET MVC基于Attribute聲明式驗證所不同的驗證組件,FluentValidation,其利用表達式語法鏈式編程,使得驗證組件與實體分開。我喜歡他的原因是喜歡表達式,喜歡鏈式的感覺,大有一氣呵成之意。
??? 進入今天的主題首先如果你還沒有這款組件,你可以利用VS2010的NuGet安裝,(如果不會的請安裝上篇開源DataBase組件:FluentMigrator中提到的方式安裝),命令為:
?
? 現在我們可以開始體驗了,實體類do任然是上節的Orders:
do:
public??class??Orders????{?
???????public?int?ID?{?get;?set;?}?
???????public?string?CustomerID?{?get;?set;?}?
???????public?decimal?DisCount?{?get;?set;?}?
???????public?DateTime?OrderDate?{?get;?set;?}?
???}
?
驗證邏輯:
public??class??OrdersValidator:AbstractValidator<Orders>?????{?
????????public??OrdersValidator()?
????????{?
????????????RuleFor(orders?=>?orders.CustomerID).NotEmpty().Length(2,?20).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方式橫切于我們的應用程序,驗證本來就是個業務功能組件,橫切點。我也是正在如此引用我的架構。
總結
以上是生活随笔為你收集整理的流畅的验证组件:FluentValidation的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 开启mysql慢查询日志,不重启数据库的
- 下一篇: positionnbsp;absolut