我有两个问题:

Q1。“业务逻辑”在MVC模式中的具体位置是什么?我分不清模型和控制器。

Q2。“业务逻辑”与“业务规则”相同吗?如果不是,有什么区别?

如果你能用一个小例子来解释就太好了。


当前回答

Model =用于CRUD数据库操作的代码。

Controller =响应用户操作,并根据特定于组织的业务规则将用户的数据检索或删除/更新请求传递给模型。这些业务规则可以在助手类中实现,如果不是太复杂的话,也可以直接在控制器操作中实现。控制器最后要求视图更新自己,以便以新显示的形式给用户反馈,或者像'updated, thanks'之类的消息,

View =基于对模型的查询生成的UI。

关于业务规则应该放在哪里,没有硬性规定。在一些设计中,它们进入模型,而在另一些设计中,它们包含在控制器中。但我认为最好还是把它们放在控制器里。让模型只关心数据库连通性。

其他回答

为什么不引入一个服务层呢?这样你的控制器就会精简,可读性更强,所有的控制器功能都是纯粹的动作。您可以根据需要在服务层中分解业务逻辑。代码可重用性很高。对模型和存储库没有影响。

业务规则在模型中。

假设您正在为邮件列表显示电子邮件。用户单击其中一封电子邮件旁边的“删除”按钮,控制器通知模型删除条目N,然后通知视图模型已更改。

也许管理员的电子邮件永远不应该从列表中删除。这是一个业务规则,该知识属于模型。视图最终可能以某种方式表示该规则——也许模型公开了一个“IsDeletable”属性,该属性是业务规则的一个功能,因此视图中的删除按钮对于某些条目是禁用的——但视图中不包含规则本身。

模型是数据的最终把关人。您应该能够在不接触UI的情况下测试业务逻辑。

A1:业务逻辑进入MVC的模型部分。Model的作用是包含数据和业务逻辑。另一方面,控制器负责接收用户输入并决定要做什么。

A2:业务规则是业务逻辑的一部分。他们有一种关系。业务逻辑具有业务规则。

看看维基百科中关于MVC的条目。转到概览,其中提到MVC模式的流程。

还可以查看维基百科中的Business Logic条目。上面提到,业务逻辑由业务规则和工作流组成。

在我看来,业务逻辑这个术语并不是一个精确的定义。Evans在他的书《领域驱动设计》中谈到了两种类型的业务逻辑:

域逻辑。 应用程序逻辑。

在我看来,这种分离要清楚得多。在认识到有不同类型的业务规则的同时,也认识到它们不一定都去同一个地方。

域逻辑是对应于实际域的逻辑。因此,如果您正在创建一个会计应用程序,那么域规则将是关于帐户、发帖、税收等的规则。在一个敏捷的软件计划工具中,规则是像基于速度和backlog中的故事点计算发布日期之类的东西。

对于这两种类型的应用程序,CSV导入/导出可能是相关的,但CSV导入/导出的规则与实际域无关。这种逻辑就是应用逻辑。

领域逻辑肯定会进入模型层。该模型还对应于DDD中的领域层。

然而,应用程序逻辑并不一定要放在模型层中。这些规则可以直接放在控制器中,也可以创建一个单独的应用程序层来承载这些规则。在这种情况下,什么是最合乎逻辑的取决于实际的应用程序。

Q1:

业务逻辑可以分为两类:

域逻辑,如电子邮件地址上的控件(唯一性、约束等),获取产品的发票价格,或者根据其产品对象计算购物车的总价。 更广泛和复杂的工作流被称为业务流程,例如控制学生的注册流程(通常包括几个步骤,需要不同的检查,有更复杂的约束)。

第一类属于模型,第二类属于控制器。这是因为第二类中的情况是广泛的应用程序逻辑,将它们放在模型中可能会混淆模型的抽象(例如,不清楚我们是否需要将这些决策放在一个模型类中还是另一个模型类中,因为它们与两者都相关!)

请看这个答案,了解模型和控制器之间的具体区别,这个链接有非常精确的定义,这个链接还有一个很好的Android示例。

重点是上面“Mud”和“Frank”提到的注释可能是正确的,“Pete”的注释也是正确的(根据业务逻辑的类型,业务逻辑可以放在模型或控制器中)。

最后,注意MVC因上下文而异。例如,在Android应用程序中,建议一些不同于基于web的定义(参见这篇文章的例子)。


Q2:

业务逻辑更一般,(正如上面提到的“反气旋”)它们之间的关系如下:

业务规则业务逻辑