那天在MSDN看到一片比较cool的文章A Simple Business Rules Manager。这篇文章中演示了如何通过委托建立一个简单的业务规则引擎,使得能够集中校验应用程序中的业务规则。
看了之后感觉非常实用,不过这个组件实用VB.NET 写的,所以我尝试着把它用C#重写了一遍。因为我不会VB.NET,在重写的过程中还是遇到了很多问题,呵呵:)要是重写的有什么问题,希望大家能够 Mail给我:liy@lonwin.com.cn
下面我简单的说一下这个组件的思路,具体的请参考源代码和上面提及的那片英文文章:
在很多系统中业务规则总是到处被复制,也就是相同的业务逻辑可能到处都是。比如一个典型的应用程序,有两个不同的Form,都需要和同一个Customer Data交互。对于Customer Data得业务逻辑在任何地方都是相同的,但是我们需要在两个不同的Form中使用这些数据,所以有时候我们需要复制义务逻辑。如下图所示:
Figure 1. Duplicated business logic
显然,这样的应用程序时很难维护的。当然我们能够把业务逻辑封装到一个对象当中,然后在不同的Form中使用相同的对象。
Figure 2. Business logic centralized in an object
把业务逻辑封装到一个对象中已经是一大进步了,不过这并不是最完美的。因为我们在这个封装的泪中依然可以复制业务逻辑。比如:
Figure 3. Business logic duplicated within an object
我们需要一个简单的方法来集中处理这些逻辑,不管是用业务对象还是ADO.NET对象。
Figure 4. Business logic centralized in a rules manager
这样就能集中处理业务规则,而不用担心到处复制这些讨厌的业务规则了:)