草庐IT

php - 在哪里建立新的领域实体? Controller 、存储库或映射器?

coder 2024-01-03 原文

假设对于每个域实体,我都有一个为数据映射器提供 API 的存储库。例如,如果我有一个 UserEntity,那么我会有一个 UserRepository,它与 UserMapper 对话以将用户数据保存在数据库中。

现在,假设在网页上提交了一个表单,我的 Controller 知道它需要根据提交的信息创建一个新的 UserEntity。

是否:

  1. 当场做 new UserEntity(),根据提交的表单数据运行所有必要的 setter 方法,然后将 UserEntity 传递给 repo,repo 传递给 mapper 进行插入?

    Controller 创建 UserEntity => Repo => Mapper => DB

  2. 将表单数据转换为数组,并将其传递给 UserRepository,然后 UserRepository 运行 new UserEntity() 和 setter,并将其传递给映射器以进行插入?

    Controller 传递用户数据 => Repo 创建 UserEntity => Mapper => DB

  3. 将数组传递给 UserRepository,UserRepository 将数组传递给映射器以用于新的 UserEntity 和插入?

    Controller 传递用户数据 => Repo 传递用户数据 => Mapper 创建 UserEntity => DB

谁负责管理对象的创建?

最佳答案

我知道这个问题很老,但我想我应该把我的想法放在这里,因为唯一的答案还没有被正式接受,这可能对 future 的搜索者有帮助。要直接回答您的问题,我不会说以上任何一个。我更喜欢有一个额外的服务,如果你愿意的话,一个“经理”,用于协调 Controller 和 repo/mapper 对象之间的交互。每个模型都有一个专门的管理器来处理其创建、更新和删除。

Controller

我认为 Controller 是应用程序的粘合剂。我们可以将所有我们想要的关注点分成尽可能多的部分,但是沿着这条线的某个地方,某些东西必须同时理解 View 端和模型端,而那个对象就是 Controller 。话虽这么说,我认为 Controller 应该很瘦,所以 Controller 唯一真正的工作是将请求映射到响应。任何类型的中间处理都应该在其他地方开始。

在 CRUD 应用程序中,很容易通过实例化新对象并将它们持久化到 Controller 中,即使它不止一次完成,因为只需粘贴几行。如果对象创建不是微不足道的呢?我正在维护一个具有许多复杂关系的应用程序,并且用户提交的创建通常需要同时创建许多对象。这在只有 Controller 和模型的环境中维护是不可行的。

额外的服务层

为了处理这个问题,我创建了 2 个额外的服务层:FormHandler 和 Manager。每次提交表单时,表单内容都会发送到表单处理层。表单处理程序负责理解传入的表单数据并对其进行规范化。然后表单处理程序可以将数据传递给适当的管理器对象进行处理。管理器对象处理数据并更新域层。他们负责创建模型、更改模型并将它们持久保存到后端。

通过这种方式, Controller 了解 Request、Response、Form(可能,如果您的框架支持服务器端表单创建)和 FormHandler。表单处理程序了解表单(或表单数据)和管理器。经理了解存储库、映射器和模型。注意,现在,管理器是与模型和映射器交互的唯一点,他们不知道表单数据或请求或响应。另一方面, Controller 和表单处理程序不需要了解域层数据或持久性。

结论

采用这种设计:

Controller -> FormHandler -> ModelManager -> Mapper

我发现我的所有类现在都可以进行单元测试(甚至在某种程度上是 Controller ),因为关注点分离得很好,而且单点交互有利于避免重复逻辑。

注意事项

我心目中的 repo 只是为了查询数据库——询问它是否有东西,而不是创建新东西。

我在这种情况下的经验来自使用 Symfony 2 和 Doctrine 2。

YMMV;例如您可能会发现表单层是不必要的,但我发现它非常方便将数据从表单/ View 数据转换为领域模型可以理解的内容。

关于php - 在哪里建立新的领域实体? Controller 、存储库或映射器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9728390/

有关php - 在哪里建立新的领域实体? Controller 、存储库或映射器?的更多相关文章

  1. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  2. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  3. ruby-on-rails - rails : How to make a form post to another controller action - 2

    我知道您通常应该在Rails中使用新建/创建和编辑/更新之间的链接,但我有一个情况需要其他东西。无论如何我可以实现同样的连接吗?我有一个模型表单,我希望它发布数据(类似于新View如何发布到创建操作)。这是我的表格prohibitedthisjobfrombeingsaved: 最佳答案 使用:url选项。=form_for@job,:url=>company_path,:html=>{:method=>:post/:put} 关于ruby-on-rails-rails:Howtomak

  4. ruby-on-rails - 如何在 Rails Controller Action 上触发 Facebook 像素 - 2

    我有一个ruby​​onrails应用程序。我按照facebook的说明添加了一个像素。但是,要跟踪转化,Facebook要求您将页面置于达到预期结果时出现的转化中。即,如果我想显示客户已注册,我会将您注册后转到的页面作为成功对象进行跟踪。我的问题是,当客户注册时,在我的应用程序中没有登陆页面。该应用程序将用户带回主页。它在主页上显示了一条消息,所以我想看看是否有一种方法可以跟踪来自Controller操作而不是实际页面的转化。我需要计数的Action没有页面,它们是ControllerAction。是否有任何人都知道的关于如何执行此操作的gem、文档或最佳实践?这是进入布局文件的像素

  5. ruby-on-rails - Controller 中的 Rails 辅助模块 - 2

    我有一个Controller,我想为这个Controller创建一个助手,我可以在不包含它的情况下使用它。我尝试像这样创建一个与Controller同名的助手classCars::EnginesController我创建的助手是moduleCars::EnginesHelperdefcheck_fuellogger.debug("chekingfuel")endend我得到的错误是undefinedlocalvariableormethod`check_fuel'for#有没有我遗漏的约定? 最佳答案 如果你真的想在Controll

  6. ruby-on-rails - 在 Controller 中干净地处理多个过滤器(参数) - 2

    我有一个名为Post的类,我需要能够适应以下场景:如果用户选择了一个类别,则只显示该类别的帖子如果用户选择了一种类型,则只显示该类型的帖子如果用户选择了一个类别和类型,则只显示该类别中该类型的帖子如果用户没有选择任何内容,则显示所有帖子我想知道我的Controller是否不可避免地会因大量条件语句而显得粗糙...这是我解决此问题的错误方法-有谁知道我如何才能做到这一点?classPostsController 最佳答案 您最好遵循“胖模型,瘦Controller”的惯例,这意味着您应该将这种逻辑放在模型本身中。Post类应该能够报告

  7. ruby-on-rails - 优雅的 Rails : multiple routes, 相同的 Controller Action - 2

    让多条路线去同一条路的最优雅的方式是什么ControllerAction?我有:get'dashboard',to:'dashboard#index'get'dashboard/pending',to:'dashboard#index'get'dashboard/live',to:'dashboard#index'get'dashboard/sold',to:'dashboard#index'这很丑陋。有什么“更优雅”的建议吗?一个类轮的奖励积分。 最佳答案 为什么不只有一个路由和一个Controller操作,并根据传递给它的参数来

  8. jquery - 如何将 AJAX 变量从 jQuery 传递到他们的 Controller ? - 2

    我有一个电子邮件表格。但是我正在制作一个测试电子邮件表单,用户可以在其中添加一个唯一的电子邮件,并让电子邮件测试将其发送到该特定电子邮件。为了简单起见,我决定让测试电子邮件通过ajax执行,并将整个内容粘贴到另一个电子邮件表单中。我不知道如何将变量从我的HAML发送到我的Controllernew.html.haml-form_tagadmin_email_blast_pathdoSubject%br=text_field_tag'subject',:class=>"mass_email_subject"%brBody%br=text_area_tag'message','',:nam

  9. ruby-on-rails - ActiveRecord::Associations::CollectionProxy 从哪里获取.each 实例方法? - 2

    假设我有模型Topics和Posts,其中Topichas_many:posts和Postbelongs_to:topic。此时我的数据库中已经有了一些东西。如果我进入Rails控制台并输入Topic.find(1).posts我相信我得到了一个CollectionProxy对象。=>#]>我可以对此调用.each以获得枚举器对象。=>#]:each>我对CollectionProxy如何处理.each感到困惑。我意识到它在某些时候是继承的,但我一直在阅读API文档,他们并没有说得很清楚CollectionProxy是从什么继承的,除非我遗漏了一些明显的东西。Thispage似乎并没有

  10. ruby - Controller 中的 request.cookies 和 cookies 有什么区别? - 2

    request.cookies和RubyonRails中的cookies对象有区别吗?我目前正在尝试将带有cookie的请求从我的node.js服务器发送到我的ROR4应用程序。似乎在ROR应用程序中,request.cookies包含我发送的cookie,但是cookies对象(现有逻辑所基于的对象)没有它。我已经搜索了文档,但找不到任何相关内容。我错过了什么吗?感谢您的帮助。 最佳答案 理想情况下,request.cookies和cookies应该相同。但是,在POST(创建操作)请求中,rails会验证XSRFtoken。如果

随机推荐