如何解决 asp.net core 中的依赖问题
依赖性注入是一种技术,它允许我们注入一个特定类的依赖对象,而不是直接创建这些实例。
使用依赖注入的好处显而易见,它通过放松模块间的耦合,来增强系统的可维护性和可测试性。
依赖注入允许我们修改具体实现,而不必改变依赖于它们的依赖类型。
asp.net core 很重视依赖注入技术。asp.net core 中内置的依赖注入提供功能模块,并不像 structuremap 和 ninject 等ioc(控制反转)容器那样功能丰富,但它速度快,易于配置,而且易于使用。我们可以使用它在 asp.net core 中注入框架服务和应用程序服务。
关于依赖注入和控制反转的有关知识可以参考:设计模式。
我们将介绍三种不同方法来解决 asp.net core 6 中的依赖项。
本文中提供的代码示例均默认运行在 visual studio 2022。
1. 使用 vs2022 创建 asp.net core 项目
我们在 visual studio 2022 中创建一个 asp.net core 项目。按照以下步骤在 visual studio 2022 中创建一个新的 asp.net core web api 6 项目。
- 1) 启动 visual studio 2022 ide。
- 2) 单击 “create new project”。
- 3) 在 “create new project” 窗口中,从显示的模板列表中选择 “asp.net core web api”。
- 4) 点击下一步。
- 5) 在 “configure your new project” 窗口中,指定新项目的名称和位置。
- 6) 根据您的偏好,可选择选中 “place solution and project in the same directory” 复选框。
- 7) 点击下一步。
- 8) 在接下来显示的 “additional information” 窗口中,从顶部的下拉列表中选择 .net 6.0 作为目标框架。将 “authentication type” 保留为 “none”(默认)。
- 9) 确保未选中 “enable docker,”、“configure for https” 和 “enable open api support” 复选框,因为我们不会在此处使用任何这些功能。您也可以选择取消选中 “use controllers(取消选中以使用最少的 api)” 复选框,因为我们将创建自己的控制器。
- 10) 单击创建。
这将在 visual studio 2022 中创建一个新的 asp.net core 6 web api 项目。我们将在本文的后续部分中使用该项目来说明解析依赖项。
2. 使用构造函数注入解决依赖关系
现在创建以下接口:
public interface icustomfilelogger { public string text { get; set; } public void log(string message); }
为简单起见,我们给出一个最小的表示。
customfilelogger 类实现 icustomfilelogger 接口,代码如下:
public class customfilelogger : icustomfilelogger { public string text { get; set; } public void log(string message) { // 自己的实现逻辑 } }
如果使用的是 asp.net 5,可以在 configureservices 方法中注册一个 icustomfilelogger 类型的实例作为一个 scoped 服务。如果使用的是 asp.net 6,则直接在 program.cs 文件中注册。
services.addscoped<icustomfilelogger, customfilelogger>();
接下来,创建一个名为 defaultcontroller 的 api 控制器并输入以下代码:
[route("api/[controller]")] [apicontroller] public class defaultcontroller : controllerbase { private icustomfilelogger _logger; public defaultcontroller(icustomfilelogger logger) { _logger = logger; if(string.isnullorempty(_logger.text)) _logger.text = datetime.utcnow.tostring(); } [httpget] public string get() { return "hello world!"; } }
注意这里是如何使用构造函数注入的。defaultcontroller 类的构造函数接受 icustomfilelogger 类型的实例作为参数。
3. 使用动作方法注入解决依赖关系
当需要在多个方法中使用注入的实例时,我们应该使用构造函数注入。如果只需要在特定的动作方法中使用实例,最好在动作方法中注入实例,而不是使用构造函数注入。
以下代码片段说明了如何实现动作方法注入。
[httppost("log")] public iactionresult log([fromservices] icustomfilelogger customfilelogger) { // 自己的实现逻辑 return ok(); }
4. 使用 iserviceprovider 解决依赖关系
我们有时候可能经常需要在控制器中注入许多不同的服务。如果使用构造函数注入,则必须在构造函数中指定多个参数。所以,这种场景下,有一个更好的解决方案,就是使用 iserviceprovider。
我们可以使用 iservicecollection 接口来创建依赖项注入容器。一旦创建了容器,iservicecollection 实例就会组合成一个 iserviceprovider 实例。我们可以使用此实例来解析服务。
我们可以将 iserviceprovider 类型的实例注入到类的任何方法中。您还可以利用 iapplicationbuilder 接口的 applicationservices 属性和 httpcontext 类的 requestservices 属性来检索 iserviceprovider 实例。
以下代码说明了如何注入 iserviceprovider 类型的实例:
public class defaultcontroller : controller { private iserviceprovider _provider; public defaultcontroller(iserviceprovider provider) { _provider = provider; } }
我们可以在操作方法中使用以下代码,来检索需要的任何服务实例。
icustomfilelogger logger = (icustomfilelogger)_provider.getservice(typeof(icustomfilelogger));
注意 iserviceprovider 的 getservice 方法是如何用来检索服务实例的。
我们可以使用 httpcontext 类的 requestservices 属性来检索 iserviceprovider 类型的实例,然后使用该实例调用 getservice 方法。
以下代码展示了httpcontext 类如何做到检索实例:
icustomfilelogger logger = (icustomfilelogger)httpcontext.requestservices.getservice(typeof(icustomfilelogger));
总结
依赖性注入是一种通过放松耦合来增强代码维护和可测试性的方法。
我们可以使用 asp.net core 中内置的依赖注入支持来创建模块化、精简和干净的应用程序,同时也使应用程序更容易维护和测试。
参考资料:
以上就是asp.net core中的依赖问题解决方法示例的详细内容,更多关于asp.net core依赖解决的资料请关注代码网其它相关文章!
发表评论