JSON 파일에서 종속성 주입을 구성하는 ASP.NET Core에 대한 자세한 설명

高洛峰
풀어 주다: 2017-02-07 11:38:42
원래의
1278명이 탐색했습니다.

오늘은 json 파일에 의존성 주입을 설정하는 방법을 소개하겠습니다.

이전 ASP.NET 4+(MVC, Web Api, Owin, SingalR 등)에서는 일반적으로 사용되는 Using Autofac, Untiy와 같은 타사 종속성 주입 구성 요소를 사용하기 위한 독점 인터페이스가 제공되었습니다. , String.Net 등에서 이러한 타사 종속성 주입 구성 요소는 기본적으로 클래스에 직접 구성하는 것 외에도 json 등을 사용하여 구성 주입 또는 구성 수명 주기 방법을 제공합니다. .. 그러면 새로운 ASP.NET Core에서 Microsoft는 기본적으로 종속성 주입 기능을 제공했습니다. 종속성 주입을 구현하기 위해 더 이상 타사 구성 요소에 의존할 필요가 없지만 때로는 종속성 주입을 구성하려면 구성 파일인 경우 Microsoft 자체 DI 구성 요소에서는 구성 파일을 제공하지 않으므로 이 구성 항목의 기능을 직접 구현해야 합니다. 개인적으로 나는 주요 사용 시나리오가 컴파일 타임에 구현을 결정할 수 없고 구현을 동적으로 수정해야 하는 곳이라고 생각합니다.

이를 수행하는 방법을 살펴보겠습니다.

시작하기

먼저 애플리케이션에서 DI 사용을 위한 인터페이스를 생성합니다.

public interface IFoo
{
  string GetInputString(string input);
}
로그인 후 복사

그런 다음 IFoo 인터페이스를 추가합니다. Foo 구현

public class Foo : IFoo
{
  public string GetInputString(string input)
  {
    return $"输入的字符串为:{ input }";
  }
}
로그인 후 복사

다음으로 위의 IFoo 인터페이스와 해당 구현을 Startup.cs 파일의 ConfigureServices 메서드에 추가해야 합니다. ConfigureServices는 주로 종속성 주입 서비스를 구성하는 데 사용됩니다. 그런 다음 이 메서드에서 제공하는 ISerciceCollection 인터페이스 매개 변수를 통해 서비스가 주입됩니다.

public void ConfigureServices(IServiceCollection services)
{
  services.Add(new ServiceDescriptor(serviceType: typeof(IFoo),
                    implementationType: typeof(Foo),
                    lifetime: ServiceLifetime.Transient));
}
로그인 후 복사

여기에서는 IServiceCollection의 Add 메서드를 사용하여 임시 수명 주기가 있는 IFoo 구현을 추가합니다. 일시적이란 Foo 인스턴스가 요청될 때마다 생성된다는 의미입니다.

위는 Microsoft에서 종속성 주입을 추가하기 위해 제공하는 기본 방법입니다. 이를 json 파일을 사용하는 데 필요한 방식으로 변환하는 방법을 살펴보겠습니다.

json 파일을 사용하여 DI 구성

json 파일을 사용하여 종속성 주입을 구성할 때 새 json 파일을 생성하거나 appsettings.json 파일을 직접 사용할 수 있습니다. 이제 appsettings.json 파일에 DI 구성을 직접 추가하겠습니다.

appsettings.json

"Logging": {
  "IncludeScopes": false,
  "LogLevel": {
   "Default": "Debug",
   "System": "Information",
   "Microsoft": "Information"
  }
 },
 
 "DIServices": [
  {
   "serviceType": "[namesapce].IFoo",
   "implementationType": "[namesapce].Foo",
   "lifetime": "Transient"
  }
 ]
}
로그인 후 복사

먼저 "DIServices"라는 배열 노드를 추가합니다. 배열에는 서비스 유형을 나타내는 하나 이상의 개체가 포함되어 있습니다. 인터페이스,implementationType 인터페이스의 구현 및 초기화된 인스턴스의 수명입니다.

참고: 구성 파일의 유형은 전체 이름이어야 합니다. 즉, 네임스페이스를 포함해야 합니다.

다음으로 Json 파일 구성 항목에 해당하는 서비스 클래스를 추가합니다. 여기서는 Newtonsoft json 라이브러리를 사용해야 합니다.

using Microsoft.Extensions.DependencyInjection;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
 
public class Service
{
  public string ServiceType { get; set; }
 
  public string ImplementationType { get;set; }
 
  [JsonConverter(typeof(StringEnumConverter))]
  public ServiceLifetime Lifetime { get; set; }
}
로그인 후 복사

그런 다음 ConfigureServices를 수정하고 ConfigureServices에서 구성된 json 파일을 읽어야 합니다.

public void ConfigureServices(IServiceCollection services)
{
  //services.Add(new ServiceDescriptor(serviceType: typeof(IFoo),
  //            implementationType: typeof(Foo),
  //            lifetime: ServiceLifetime.Transient));
 
  var jsonServices = JObject.Parse(File.ReadAllText("appSettings.json"))["DIServices"];
  var requiredServices = JsonConvert.DeserializeObject<List<Service>>(jsonServices.ToString());
 
  foreach (var service in requiredServices) {
    services.Add(new ServiceDescriptor(serviceType: Type.GetType(service.ServiceType),
                      implementationType: Type.GetType(service.ImplementationType),
                      lifetime: service.Lifetime));
  }
}
로그인 후 복사

그런 다음 사용 가능한지 테스트합니다.

테스트

HomeController.cs를 열고 주입 항목을 추가합니다.

public class HomeController : Controller
{
  private readonly IFoo _foo;
 
  public HomeController(IFoo foo)
  {
    _foo = foo;
  }
 
  public IActionResult About()
  {
    ViewData["Message"] = _foo.GetInputString("Your application description page.");
 
    return View();
  }
}
로그인 후 복사

HomeController 생성자에 IFoo 인터페이스를 추가한 다음 사용 정보의 조치.

프로그램을 실행하고 페이지를 열고 About 탭을 클릭하세요

详解ASP.NET Core 在 JSON 文件中配置依赖注入

요약

위는 ASP에서 종속성 주입을 구성하는 방법입니다. .NET Core json 파일은 단순한 예일 뿐이므로 프로덕션 환경에서는 사용하면 안 됩니다. 실제 프로젝트에서는 구성을 읽을 때의 예외, 서비스 존재 여부, 라이프사이클 등의 문제도 처리해야 합니다.

JSON 파일에서 종속성 주입을 구성하는 ASP.NET Core에 대한 자세한 설명은 PHP 중국어 웹사이트의 관련 기사를 참고하세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!