服务注册自治,降低 ASP.NET Core Web API 依赖注入的耦合度和复杂度

简介: 服务注册自治,降低 ASP.NET Core Web API 依赖注入的耦合度和复杂度

前言

在软件的实际开发中,一个软件通常由多个项目组成,这些项目都会直接或者间接被主 ASP.NET Core 项目引用。

这些项目中通常都会用到若干个被注入的服务,因此我们需要在主 ASP.NET Core 项目的 Program.cs 中注册这些服务。这样不仅会增加了 Program.cs 管理的复杂度,而且也增加了项目的耦合度。

如果能让各个项目负责各自的服务注册,就能够减小项目之间的耦合度。

Step By Step 步骤

  1. 创建类库项目 "SampleService”
  2. 创建接口IMyService
namespace SampleService
{
  public interface IMyService
  {
    void SayHello();
  }
}

3.创建类库项目 "SampleServiceImpl1” ,并引用 "SampleService” 项目

4.创建 IMyService 的实现类 CnService

using SampleService;
namespace SampleServiceImpl1
{
  public class CnService : IMyService
  {
    public void SayHello()
    {
      Console.WriteLine("你好");
    }
  }
}

5.引用 Nuget 包 Zack.Commons

6.创建Zack.Commons中的 IModuleInitializer 接口的实现类 ModuleInitializer

using Microsoft.Extensions.DependencyInjection;
using Zack.Commons;
using SampleServiceImpl1;
using SampleService;
class ModuleInitializer : IModuleInitializer
{
  public void Initialize(IServiceCollection services)
  {
    // 把 CnService 注册为 IMyService 的实现服务
    services.AddScoped<IMyService, CnService>();
  }
}

7.创建类库项目 "SampleServiceImpl2” ,重复 3~6 步骤,注意不同的代码:

  1. IMyService 的实现类 EnService
using SampleService;
namespace SampleServiceImpl2
{
  public class EnService : IMyService
  {
    public void SayHello()
    {
      Console.WriteLine("Hello");
    }
  }
}
  1. IModuleInitializer 接口的实现类 ModuleInitializer
using Microsoft.Extensions.DependencyInjection;
using Zack.Commons;
using SampleServiceImpl2;
using SampleService;
class ModuleInitializer : IModuleInitializer
{
  public void Initialize(IServiceCollection services)
  {
    // 把 EnService 注册为 IMyService 的实现服务
    services.AddScoped<IMyService, EnService>();
  }
}

8.创建控制台项目 "MainProject”

9.引用 "SampleService” , "SampleServiceImpl1” , "SampleServiceImpl2” 这三个项目

10.引用 Nuget 包 Microsoft.Extensions.DependencyInjection

11.打开 Program.cs,编写服务注册和使用代码(重点看注释

using Microsoft.Extensions.DependencyInjection;
using SampleService;
using Zack.Commons;
// 1.创建服务注册容器
ServiceCollection services=new ServiceCollection();
// 2.调用 GetAllReferencedAssemblies 方法获取所有的用户程序集
var assemblies = ReflectionHelper.GetAllReferencedAssemblies();
// 3.调用 RunModuleInitializers 方法扫描指定程序集中所有实现了 IModuleInitializer 接口的类
//   并且调用它们的Initialize方法来完成服务的注册
services.RunModuleInitializers(assemblies);
// 4.使用
using var sp = services.BuildServiceProvider();
var items = sp.GetServices<IMyService>();
foreach (var item in items)
{
  item?.SayHello();
}

总结

控制台项目 "MainProject” 只是添加了对 "SampleServiceImpl1” 和 "SampleServiceImpl2” 的引用,

但是在项目 "MainProject” 中并没有使用代码注册 CnService 服务和 EnService 服务,服务的注册工作是由 "SampleServiceImpl1” 中的 ModuleInitializer 类完成的。

这样,我们就减小了项目之间的耦合度,实现了程序集的 "服务注册自治”


相关文章
|
22天前
|
开发框架 .NET API
Windows Forms应用程序中集成一个ASP.NET API服务
Windows Forms应用程序中集成一个ASP.NET API服务
77 9
|
23天前
|
存储 开发框架 .NET
.NET 8 实现无实体库表 API 部署服务
【10月更文挑战第12天】在.NET 8中,可通过以下步骤实现无实体库表的API部署:首先安装.NET 8 SDK及开发工具,并选用轻量级Web API框架如ASP.NET Core;接着创建新项目并设计API,利用内存数据结构模拟数据存储;最后配置项目设置并进行测试与部署。此方法适用于小型项目或临时解决方案,但对于大规模应用仍需考虑持久化存储以确保数据可靠性与可扩展性。
|
2月前
|
存储 API 数据库
如何使用 ef core 的 code first(fluent api)模式实现自定义类型转换器?
本文介绍了如何在 EF Core 的 Code First 模式下使用自定义类型转换器实现 JsonDocument 和 DateTime 类型到 SQLite 数据库的正确映射。通过自定义 ValueConverter,实现了数据类型的转换,并展示了完整的项目结构和代码实现,包括实体类定义、DbContext 配置、Repositories 仓储模式及数据库应用迁移(Migrations)操作。
60 6
如何使用 ef core 的 code first(fluent api)模式实现自定义类型转换器?
|
2月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
2月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
75 3
|
2月前
|
开发框架 前端开发 .NET
VB.NET中如何利用ASP.NET进行Web开发
在VB.NET中利用ASP.NET进行Web开发是一个常见的做法,特别是在需要构建动态、交互式Web应用程序时。ASP.NET是一个由微软开发的开源Web应用程序框架,它允许开发者使用多种编程语言(包括VB.NET)来创建Web应用程序。
49 5
|
25天前
|
监控 安全 API
Docker + .NET API:简化部署和扩展
Docker + .NET API:简化部署和扩展
33 0
|
26天前
|
监控 安全 API
最完美的扩展Docker + .NET API:简化部署和扩展
最完美的扩展Docker + .NET API:简化部署和扩展
43 0
|
26天前
|
API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
19 0
|
3月前
|
UED 存储 自然语言处理
【语言无界·体验无疆】解锁Vaadin应用全球化秘籍:从代码到文化,让你的应用畅游世界每一个角落!
【8月更文挑战第31天】《国际化与本地化实战:构建多语言支持的Vaadin应用》详细介绍了如何使用Vaadin框架实现应用的国际化和本地化,提升用户体验和市场竞争力。文章涵盖资源文件的创建与管理、消息绑定与动态加载、日期和数字格式化及文化敏感性处理等方面,通过具体示例代码和最佳实践,帮助开发者构建适应不同语言和地区设置的Vaadin应用。通过这些步骤,您的应用将更加灵活,满足全球用户需求。
51 0