首頁 > 軟體

ASP.NET Core MVC 依賴注入View與Controller

2021-09-23 13:01:55

一、ASP.NET Core MVC 之依賴注入 View

  ASP.NET Core 支援在試圖中使用依賴注入。這將有助於提供檢視專用的服務,比如在地化或者僅用於填充檢視元素的資料。應儘量保持控制器和檢視之間的關注點分離。檢視所顯示的大部分資料應該從控制器傳入。

  使用 @inject 指令將服務注入到檢視,語法 @inject <type> <name> 

例如:

@model MVCTest.Models.Operation
@using MVCTest.Services
@inject BaseInfoServices BaseInfoServices

@{
    ViewData["Title"] = "Create";
}
<ul>
    @foreach (var city in BaseInfoServices.GetCities())
    {
    <li>@city</li>
    }
</ul>

    public class BaseInfoServices
    {
        public List<string> GetCities()
        {
            return new List<string>();
        }
    }

  需要提前在 ConfigureServices 中設定,將該服務加入到容器。

 1.填充查詢資料

  檢視注入有助於填充 UI 元素,例如下拉框列表。比如一個包括性別,州以及其他使用者資料的表單。如果通過標準的 MVC 方式渲染這個表單,則需要控制器為每一組選項都請求資料存取服務,然後將每一組繫結的選項填充到模型或ViewBag中。

  另一種則是直接將服務注入到檢視中以獲取這些選項資料。這種方法將控制器程式碼量減少到最少,把構造檢視元素的邏輯移到檢視本身去。控制器 Action 只需把使用者資料資料傳個表單即可。

2.重寫服務

  除了注入服務外,此技術還可用於重寫頁面上先前注入的服務。例如,替換預設的HTML Helper

@model MVCTest.Models.Operation
@using MVCTest.Services
@inject BaseInfoServices BaseInfoServices
@inject MyHtmlHelper Html


  在檢視中使用 @Html 將會呼叫自定義的服務。

  如果想要擴充套件現有服務而不是替換,則只需在使用此技術的同時,讓服務繼承或者封裝已有實現即可。

二、 ASP.NET Core MVC 之依賴注入 Controller

ASP.NET Core MVC 控制器應通過建構函式明確地請求它們地依賴關係,在某些情況下,單個控制器地操作可能需要一個服務,在控制器級別上的請求可能沒有意義。在這種情況下,也可以將服務作為  Action 的引數。

  依賴注入是一種如 Dependency Inversion Principle 所示的技術,允許應用程式鬆散耦合的模組組成。

1.建構函式注入

  ASP.NET Core 內建的基於建構函式的依賴注入支援擴充套件到 MVC 控制器。通過只新增一個服務型別作為建構函式引數到控制器中,ASP.NET Core 將會嘗試使用內建服務容器解析這個型別。服務通常(但不總是)使用介面定義。例如,如果應用程式定義一個檢索時間的服務,然後依賴注入而不是寫死:

定義介面和實現:

namespace MVCTest.Services
{
    public interface IDateTime
    {
        DateTime Now { get; }
    }
    public class SystemDateTime: IDateTime
    {
        public DateTime Now
        {
            get { return DateTime.Now; }
        }
    }
}

ConfigureServices 中註冊服務到容器:

services.AddTransient<IDateTime, SystemDateTime>();


在控制其中使用:

    public class DateTimeController : Controller
    {
        private IDateTime _dateTime;
        public DateTimeController(IDateTime dateTime)
        {
            _dateTime = dateTime;
        }
        // GET: DateTime
        public ActionResult Index()
        {
            var serverTime = _dateTime.Now;
            if (serverTime.Hour < 12)
            {
                ViewData["Message"] = "Good Morning";
            }
            return View();
        }
}

  ASP.NET Core 內建的依賴注入支援用於請求服務的型別只能有一個建構函式,如果多於一個會報異常。使用第三方實現替換預設依賴注入,可以實現支援多個建構函式。

2.使用 FromServices 操作注入

  有時,不需要在控制器為多個操作提供服務。在這種情況下,將服務注入到操作方法的引數是有意義的。通過 [FromServices] 標記引數來實現:

  public ActionResult Index([FromServices] IDateTime _dateTime)
        {
            var serverTime = _dateTime.Now;
            if (serverTime.Hour < 12)
            {
                ViewData["Message"] = "Good Morning";
            }
            return View();
        }

 3.在控制器中存取設定

  在控制器中存取應用程式設定或者設定設定時常見的模式。此存取應當使用在 Configuration 中描述的存取模式。通常不應從控制器中使用依賴注入直接請求設定,更好的方式是請求 IOptions<T> 範例,T是你需要的設定型別。例如:

建立選項類:

public class AppSettingOptions
    {
        public DefaultConnec ConnectionStrings { get; set; }
        public string AllowedHosts { get; set; }
    }

    public class DefaultConnec
    {
        public string DefaultConnection { get; set; }
    }

appsettings.json:

{
  "ConnectionStrings": {
    "DefaultConnection": "Data Source=.;Initial Catalog=Test;Integrated Security=True"
  },
  "Logging": {
    "LogLevel": {
      "Default": "Information"
    }
  },
  "AllowedHosts": "*"
}

設定應用程式使用選項模型,在 ConfigureServices 中新增設定類到服務容器:

public Startup(IConfiguration configuration,IHostingEnvironment env)
        {
            //Configuration = configuration;
            var builder = new ConfigurationBuilder()
                .SetBasePath(Directory.GetCurrentDirectory())
                .AddJsonFile("appsettings.json",optional:true,reloadOnChange:true)
                //.AddJsonFile($"appsettings.{env.EnvironmentName}.json",optional:true)
                ;

            //設定環境變數
            //builder.AddEnvironmentVariables();
            Configuration = builder.Build();
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddOptions();
            services.Configure<AppSettingOptions>(Configuration);
            //通過程式碼編寫
            services.Configure<AppSettingOptions>(options=>
            {
                options.AllowedHosts = "test";
            });
        }

範例是從 appsettings.json 讀取設定,也可以在程式碼中新增設定。

  一旦指定了請型別的設定物件 AppSettingOptions,並將其新增到服務容器,就可以在控制器或操作方法通過請求 IOptions<AppSettingOptions>  的範例獲取它:

    public class HomeController : Controller
    {
        private readonly IOptions<AppSettingOptions> _options;
        public HomeController(IOptions<AppSettingOptions> options)
        {
            _options = options;
        }
}

  遵循選項模式允許將設定和設定彼此分離,並且確保控制器遵循關注點分離,因為不需要知道如何在哪裡找到設定資訊。由於控制器類中沒有靜態附著或者直接範例化設定類,因此使得控制器更容易使用單元測試。

到此這篇關於ASP.NET Core MVC 依賴注入View與Controller的文章就介紹到這了,更多相關ASP.NET Core MVC 依賴注入內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com