Web开发:ABP框架中的服务调用原则--避免服务之间的直接依赖

2024-08-30 08:28

本文主要是介绍Web开发:ABP框架中的服务调用原则--避免服务之间的直接依赖,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

示意图

(Service之间可以相互调用,使用依赖倒置原则:例如某个服务可注入到另一个服务,用法:private readonly IyyyService _yyyService;) 

命名约定

  • WebAPI 控制器: 建议命名为 XXXXController 或 XXXXManagementController(也有的命名为XXXXManagementService,主要用于处理HTTP请求
  • 业务逻辑层服务(BLL): 命名为 XXXXService,主要用于增删改查和写基本逻辑,通常会被 Web API 控制器调用。
  • 数据访问层仓储(DAL): 使用 XXXXRepository 命名, ORM(对象关系映射)处理,很可能用到反射之类的技术。

接口定义

  • 通常,为了实现解耦和便于测试,建议为业务逻辑层服务 (XXXXService) 和数据访问层仓储 (XXXXRepository) 定义接口。这些接口可以放在 Application.Contracts 命名空间下。
  • 责任: 定义服务和仓储层的合同,以便于实现依赖注入和松耦合。

参数设计

  • 在设计业务逻辑层服务(BLL)的方法时,推荐使用列表类型作为输入参数和返回值,这样可以更好地支持批量操作,并提高代码的重用性。对于复杂的数据交互,可以考虑使用专门的 DTO(数据传输对象)。

调用关系

  • 一个 WebAPI 控制器不允许调用另一个 WebAPI 控制器。
  • 直接的控制器间调用可能会导致架构复杂度增加维护困难调试困难。更好的做法是通过服务层 (XXXXService) 进行协调,将所需的业务逻辑封装在服务层内部,然后由需要的控制器调用相应的服务方法来获取或处理数据。
  • 如果两个Webapi控制器相互注入,会导致循环依赖从而无法解析依赖,导致程序无法启动或启动后增加额外开销,影响系统稳定性

反例:

[HttpGet]
[Route("GetMenuAsync")]//MenuManageService.cs
public async Task GetMenuAsyncc(IputDto input)
{var com_list = (await _componentManageService.GetListAsync());
}[HttpGet]
[Route("GetListAsync")]//componentManageService.cs
public async Task<PagedResultDto<ComponentTypeDto>> GetListAsync(ComponentTypeDto input)
{//省略方法
}

        综上所述,在实际开发过程中,尽量避免控制器之间的直接调用,而是通过共享的服务层来协调不同的业务需求,这样可以确保系统架构更加清晰、易于维护。

这篇关于Web开发:ABP框架中的服务调用原则--避免服务之间的直接依赖的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120300

相关文章

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

Idea调用WebService的关键步骤和注意事项

《Idea调用WebService的关键步骤和注意事项》:本文主要介绍如何在Idea中调用WebService,包括理解WebService的基本概念、获取WSDL文件、阅读和理解WSDL文件、选... 目录前言一、理解WebService的基本概念二、获取WSDL文件三、阅读和理解WSDL文件四、选择对接

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python