ASP.NET Core 中框架级依赖注入是如何实现和配置的?

2026-04-01 10:551阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1195个文字,预计阅读时间需要5分钟。

ASP.NET Core 中框架级依赖注入是如何实现和配置的?

在ASP.NET Core中,依赖注入是框架的核心特性之一,它允许我们在应用程序中创建灵活且可扩展的依赖关系。以下是一个简化的示例,展示了如何在ASP.NET Core中实现框架级别的依赖注入。

示例中,我们将创建一个简单的依赖注入示例,展示如何在ASP.NET Core中注入依赖。

csharppublic class DependencyInjectionExample{ private readonly IServiceProvider _serviceProvider;

public DependencyInjectionExample(IServiceProvider serviceProvider) { _serviceProvider=serviceProvider; }

public void ShowDependencyInjection() { var logger=_serviceProvider.GetService(); logger.LogInformation(依赖注入示例运行中...);

// 示例:注入一个服务 var exampleService=_serviceProvider.GetService(); exampleService.DoSomething(); }}

public interface IExampleService{ void DoSomething();}

public class ExampleService : IExampleService{ public void DoSomething() { Console.WriteLine(执行了示例服务操作。); }}

在这个示例中,我们创建了一个`DependencyInjectionExample`类,它通过构造函数接收一个`IServiceProvider`实例。这个实例允许我们获取任何注册的服务。我们通过`GetService()`方法注入了一个`IExampleService`的实现,并在`DoSomething`方法中使用了它。

框架级别的依赖注入支持以下scope:

- Singleton - 每个请求只创建一次实例,后续请求将重用这个实例。

csharppublic void ShowSingletonScope(){ var logger=_serviceProvider.GetService(); logger.LogInformation(Singleton scope示例运行中...);

var singletonService=_serviceProvider.GetService(); singletonService.DoSomething();}

public interface ISingletonService{ void DoSomething();}

public class SingletonService : ISingletonService{ public void DoSomething() { Console.WriteLine(执行了Singleton服务操作。); }}

1、ASP.NET Core 中的依赖注入

此示例展示了框架级依赖注入如何在 ASP.NET Core 中工作。 其简单但功能强大,足以完成大部分的依赖注入工作。框架级依赖注入支持以下 scope:

  1. Singleton — 总是返回相同的实例
  2. Transient — 每次都返回新的实例
  3. Scoped — 在当前(request)范围内返回相同的实例

假设我们有两个要通过依赖注入来进行工作的工件:

  1. PageContext — 自定义请求上下文
  2. Settings — 全局应用程序设置

这两个都是非常简单的类。PageContext 类为布局页面提供当前页面标题的标题标签。

public class Settings { public string SiteName; public string ConnectionString; } public class PageContext { private readonly Settings _settings; public PageContext(Settings settings) { _settings = settings; } public string PageTitle; public string FullTitle { get { var title = (PageTitle ?? "").Trim(); if(!string.IsNullOrWhiteSpace(title) && !string.IsNullOrWhiteSpace(_settings.SiteName)) { title += " | "; } title += _settings.SiteName.Trim(); return title; } } }

2、注册依赖

在 UI 构建块中使用这些类之前,需要在应用程序启动时注册这些类。该工作可以在 Startup 类的 ConfigureServices() 方法中完成。

public void ConfigureServices(IServiceCollection services) { services.AddMvc(); var settings = new Settings(); settings.SiteName = Configuration["SiteName"]; services.AddSingleton(settings); services.AddScoped<PageContext>(); }

现在可以将这些类注入到支持依赖注入的控制器和其他 UI 组件中。

3、向控制器注入实例

我们通过 Home 控制器中的 PageContext 类分配页面标题。

public class HomeController : Controller { private readonly PageContext _pageContext; public HomeController(PageContext pageContext) { _pageContext = pageContext; } public IActionResult Index() { _pageContext.PageTitle = ""; return View(); } public IActionResult About() { _pageContext.PageTitle = "About"; return View(); } public IActionResult Error() { _pageContext.PageTitle = "Error"; return View(); } }

这种分配页面标题的方式不错,因为我们不必使用 ViewData,这样更容易受支持多语言应用程序支持。

4、向视图注入实例

ASP.NET Core 中框架级依赖注入是如何实现和配置的?

现在控制器的 action 中分配了页面标题,是时候在布局页面中使用标题了。 我在页面的内容区域添加了标题,所以在 tech.io 环境中也很容易看到。为了能在布局页面中使用到 PageContext,我使用了视图注入(下面代码片段中的第一行)。

@inject PageContext pageContext <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>@pageContext.FullTitle</title> <environment names="Development"> <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.css" rel="external nofollow" /> <link rel="stylesheet" href="~/css/site.css" rel="external nofollow" /> </environment> <environment names="Staging,Production"> <link rel="stylesheet" href="ajax.aspnetcdn.com/ajax/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" asp-fallback-href="~/lib/bootstrap/dist/css/bootstrap.min.css" rel="external nofollow" asp-fallback-test-class="sr-only" asp-fallback-test-property="position" asp-fallback-test-value="absolute" /> <link rel="stylesheet" href="~/css/site.min.css" rel="external nofollow" asp-append-version="true" /> </environment> </head> ... </html>

5、参考材料

ASP.NET 5 中的依赖注入(Gunnar Peipman)
ASP.NET Core:使用视图注入(Gunnar Peipman)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计1195个文字,预计阅读时间需要5分钟。

ASP.NET Core 中框架级依赖注入是如何实现和配置的?

在ASP.NET Core中,依赖注入是框架的核心特性之一,它允许我们在应用程序中创建灵活且可扩展的依赖关系。以下是一个简化的示例,展示了如何在ASP.NET Core中实现框架级别的依赖注入。

示例中,我们将创建一个简单的依赖注入示例,展示如何在ASP.NET Core中注入依赖。

csharppublic class DependencyInjectionExample{ private readonly IServiceProvider _serviceProvider;

public DependencyInjectionExample(IServiceProvider serviceProvider) { _serviceProvider=serviceProvider; }

public void ShowDependencyInjection() { var logger=_serviceProvider.GetService(); logger.LogInformation(依赖注入示例运行中...);

// 示例:注入一个服务 var exampleService=_serviceProvider.GetService(); exampleService.DoSomething(); }}

public interface IExampleService{ void DoSomething();}

public class ExampleService : IExampleService{ public void DoSomething() { Console.WriteLine(执行了示例服务操作。); }}

在这个示例中,我们创建了一个`DependencyInjectionExample`类,它通过构造函数接收一个`IServiceProvider`实例。这个实例允许我们获取任何注册的服务。我们通过`GetService()`方法注入了一个`IExampleService`的实现,并在`DoSomething`方法中使用了它。

框架级别的依赖注入支持以下scope:

- Singleton - 每个请求只创建一次实例,后续请求将重用这个实例。

csharppublic void ShowSingletonScope(){ var logger=_serviceProvider.GetService(); logger.LogInformation(Singleton scope示例运行中...);

var singletonService=_serviceProvider.GetService(); singletonService.DoSomething();}

public interface ISingletonService{ void DoSomething();}

public class SingletonService : ISingletonService{ public void DoSomething() { Console.WriteLine(执行了Singleton服务操作。); }}

1、ASP.NET Core 中的依赖注入

此示例展示了框架级依赖注入如何在 ASP.NET Core 中工作。 其简单但功能强大,足以完成大部分的依赖注入工作。框架级依赖注入支持以下 scope:

  1. Singleton — 总是返回相同的实例
  2. Transient — 每次都返回新的实例
  3. Scoped — 在当前(request)范围内返回相同的实例

假设我们有两个要通过依赖注入来进行工作的工件:

  1. PageContext — 自定义请求上下文
  2. Settings — 全局应用程序设置

这两个都是非常简单的类。PageContext 类为布局页面提供当前页面标题的标题标签。

public class Settings { public string SiteName; public string ConnectionString; } public class PageContext { private readonly Settings _settings; public PageContext(Settings settings) { _settings = settings; } public string PageTitle; public string FullTitle { get { var title = (PageTitle ?? "").Trim(); if(!string.IsNullOrWhiteSpace(title) && !string.IsNullOrWhiteSpace(_settings.SiteName)) { title += " | "; } title += _settings.SiteName.Trim(); return title; } } }

2、注册依赖

在 UI 构建块中使用这些类之前,需要在应用程序启动时注册这些类。该工作可以在 Startup 类的 ConfigureServices() 方法中完成。

public void ConfigureServices(IServiceCollection services) { services.AddMvc(); var settings = new Settings(); settings.SiteName = Configuration["SiteName"]; services.AddSingleton(settings); services.AddScoped<PageContext>(); }

现在可以将这些类注入到支持依赖注入的控制器和其他 UI 组件中。

3、向控制器注入实例

我们通过 Home 控制器中的 PageContext 类分配页面标题。

public class HomeController : Controller { private readonly PageContext _pageContext; public HomeController(PageContext pageContext) { _pageContext = pageContext; } public IActionResult Index() { _pageContext.PageTitle = ""; return View(); } public IActionResult About() { _pageContext.PageTitle = "About"; return View(); } public IActionResult Error() { _pageContext.PageTitle = "Error"; return View(); } }

这种分配页面标题的方式不错,因为我们不必使用 ViewData,这样更容易受支持多语言应用程序支持。

4、向视图注入实例

ASP.NET Core 中框架级依赖注入是如何实现和配置的?

现在控制器的 action 中分配了页面标题,是时候在布局页面中使用标题了。 我在页面的内容区域添加了标题,所以在 tech.io 环境中也很容易看到。为了能在布局页面中使用到 PageContext,我使用了视图注入(下面代码片段中的第一行)。

@inject PageContext pageContext <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>@pageContext.FullTitle</title> <environment names="Development"> <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.css" rel="external nofollow" /> <link rel="stylesheet" href="~/css/site.css" rel="external nofollow" /> </environment> <environment names="Staging,Production"> <link rel="stylesheet" href="ajax.aspnetcdn.com/ajax/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" asp-fallback-href="~/lib/bootstrap/dist/css/bootstrap.min.css" rel="external nofollow" asp-fallback-test-class="sr-only" asp-fallback-test-property="position" asp-fallback-test-value="absolute" /> <link rel="stylesheet" href="~/css/site.min.css" rel="external nofollow" asp-append-version="true" /> </environment> </head> ... </html>

5、参考材料

ASP.NET 5 中的依赖注入(Gunnar Peipman)
ASP.NET Core:使用视图注入(Gunnar Peipman)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。