- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我对 Spring-MVC 中 @Controller
、@Service
和 @Repository
的用法感到很困惑。
我有几个问题,如果能得到解答,我将不胜感激。
我知道 Controller 用于接收来自 View 的请求并向 View 发出请求以向用户显示结果。我的问题是,我可以在带有 Controller 注释的类中进行什么程度的处理?我是否应该在服务注释类中进行所有处理,并让 Controller 只接收请求和返回响应?我想知道最佳做法是什么?
假设我需要调用服务注释类的不同方法来处理结果,我应该从 Controller 中调用它们还是将它们传递给服务注释类? (这只是一个例子)
如果我不想处理结果而只想向数据库发送请求并接收结果,我是否仍需要在 Controller 和存储库之间有一个服务注释类?
假设我收到一个产品 ID 并想检索并显示产品的详细信息。(这只是一个示例)
最佳答案
我认为这几乎不是任何“最佳方法”,而是适合您需要的方法。这是我在过去的项目中使用的方法,它基于领域驱动设计。
表示层: Controller (@Controller)
仅负责呈现业务功能(在应用服务层提供)。因此主要委托(delegate)给 App Service,执行数据处理和与表示相关的逻辑。
应用服务层:应用服务(@Service)
从高层次上讲,它代表业务用例。因此,事务边界是在方法上设置的(因为每个方法都是一个用例,因此是一个工作单元)。因为我反对使用贫血模型,真正的业务逻辑应该在领域模型层。该层主要利用领域层来组成有意义的用例。主要是数据转换(取决于您的设计),以及对域层工件的委托(delegate)。
领域层:模型、领域服务 (@Service)、存储库 (@Repository) 等
业务逻辑在领域模型或领域服务中。存储库是检索域模型的工件。
基础设施层
一些域工件的依赖于基础架构的实现。
回到你的问题:
没有对错之分。如果您正在制作一个完全独立的简单应用程序,那么将 Controller 和应用程序服务层的角色分开可能没有任何好处。此外,对于那些习惯于贫血模型开发的人来说,您可能需要一个服务来放入您的业务逻辑。因此,您需要问问自己,在设计中拥有特定层的目的是什么,是吗?对你真正有意义的东西。对于我的方法,我认为对于哪一层做什么已经很清楚了。如果需要,可以作为引用。
类似的回答:如果你在你的Controller中做的是Presentation + Application Service的角色,没有特殊的理由再补一个Service。但是,如果您想维护一个表现中立的应用服务层,那么您应该通过您的应用服务提供那些“CRUD”操作。
关于java - 使用 Controller、Service 和 Repository 注释的最佳实践是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32731763/
在过去的几个月里,我一直在使用 Bzr 对我的项目进行版本控制。我是唯一的开发人员,目前我只有一个本地项目目录中的所有内容,我提交并同步到 DriveHQ。 我现在想到了一些可能会打破这条主线的大规模
我在一个多模块项目中使用 Maven 3.2.3。我想生成一个 checkstyle 和 findbugs 报告,所以我配置了以下内容:
我注意到 Repository 通常通过以下任一方式实现: 方法一 void Add(object obj); void Remove(object obj); object GetBy(int id
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
这是我的设置的详细信息: Gitlab 版本:5.2操作系统:Centos 6.3我在创建新项目 (/projects/new) 时导入现有存储库。 创建了一个新的 EMPTY 项目,但是没有导入存储
我的文件夹结构如下: repo1 | |---file1 |---fold1 | |---file2 |---repo2 | | |---file3 假设我有两
假设我有一个 TeacherRepository,需要根据下面的代码使用 CourseRepository。 Teacher 和 Course 形成多对多的关系。教师和类(class)不形成聚合。您会
我要同样的 repositories我在 buildscript.repositories 中指定的阻止与依赖项相同的存储库 repositories堵塞。请看我的例子: 正常 buidldscrip
是否使用 @EnableJpaRepositories 或 jpa:repositories(在 xml 上)让开发人员不要使用 Spring 的 @Repository 标签?当我查看 Spring
我是 git 和 Github 的新手。我已经了解了很多术语(推送、 pull 、提交、分支等),但我将主要使用通俗的说法来解释我最初的期望。 我假设过程是: 1.) Create a git rep
安装 Nexus Repository Manager OSS 3 后,我没有看到用于通过网页上传工件的选项Artifact Upload。 在 Nexus Repository Manager OS
CMS 和 DMS 有什么区别?两者都存储日期,可以访问数据,它们有什么不同?可以使用 apache Jack Rabbit 代替 Alfresco 吗? 最佳答案 我会根据管理数据的可变性来区分这两
在我的earlier question我问的是如何为使用 EF 等 ORM 框架构建的大型应用程序实现存储库/工作单元模式。 我现在无法解决的一个后续问题是将包含业务逻辑的代码放在哪里,但仍然足够低级
我正在尝试为 nuget git 存储库(我刚刚从中克隆)创建 pull 请求。我已经进行了本地提交。 但是当我尝试创建 pull 请求时,出现以下错误: Could not find any rel
我已经看到了下面的问题。 git diff between cloned and original remote repository 我的问题是如何在 SourceTree 中看到这个差异结果(而不
我在通过 Subversion (SVN) 中的 checkin 自动在 Review Board 中创建新的评论条目时遇到了困难。我创建了一个提交后 Hook ,当手动运行时会出现以下异常: Fai
我在尝试集成 Spring Data 时遇到此错误。完整的堆栈跟踪是 nested exception is org.xml.sax.SAXParseException; systemId: http
通知:https://docs.aws.amazon.com/codecommit/latest/userguide/how-to-repository-email.html 触发器:https://
我正在学习 Laravel 中的存储库设计模式,我正在使用 https://github.com/andersao/l5-repository去做这件事。 但是在我将文件夹 prettus 复制/粘贴
我最近开始了一个使用现有数据库(Oracle)和 MVC 4 的项目。已经进行了很多编码..但是代码中没有“策略”..只有 DB -> ORM -> Controller。因此,我正在尝试为开发添加一
我是一名优秀的程序员,十分优秀!