netcore專案中IStartupFilter使用

星仔007發表於2021-11-19

背景:

netcore專案中有些服務是在通過中介軟體來通訊的,比如orleans元件。它裡面服務和客戶端會指定閘道器和埠,我們只需要開放客戶端給外界,服務端關閉埠。相當於去掉host,這樣省掉了些指定配置連線和埠,用起來非常方便。

幹掉host,下面程式碼:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System;

namespace StartupFilterTest
{
    internal class Program
    {
        static void Main(string[] args)
        {
            #region Net 5

            Host.CreateDefaultBuilder(args)
               .ConfigureServices((hostContext, svc) =>
               {
                   svc.AddSingleton<IStartupFilter, MyStartupFilter>();
               })
                //.ConfigureWebHostDefaults(host =>
                //{
                //    host.UseStartup<Startup>();
                //})
                .Build().Run(); 
            #endregion


            #region Net 6
            //var builder = WebApplication.CreateBuilder();
            //builder.Services.AddSingleton<IStartupFilter,MyStartupFilter>();
            //var app = builder.Build();
            //app.Run(); 

            //WebApplicationBuilder     _bootstrapHostBuilder    ConfigureWebHostDefaults
            #endregion

        }
    }
}

 

net5裡面註釋掉的程式碼就是我們關掉的服務,跑起來相當於純控制檯了。

但是startup裡面需要寫中介軟體等程式碼的指定,這樣的話想把Startup檔案幹掉又不方便。通過找文件發現IStartupFilter可以實現這一塊的功能,代替Configure程式碼塊。

 public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
           
        }

IStartupFilter 介面只有一個方法《Action<IApplicationBuilder> Configure(Action<IApplicationBuilder> next)》只要實現它就行了,再注入到容器裡面去。

 internal class MyStartupFilter : IStartupFilter
    {
        public Action<IApplicationBuilder> Configure(Action<IApplicationBuilder> next)
        {
            return app =>
            {
                app.Run(async context => { await context.Response.WriteAsync("hello world"); });
                next(app);
            };
        }
    }
svc.AddSingleton<IStartupFilter, MyStartupFilter>();

 

但是新的問題又來了, 發現程式跑起來完全不會執行到MyStartupFilter裡面去,這是為什麼呢?喵了下原始碼發現IStartupFilter介面的實現是放到webhost裡面

的,所以只能指定Host了。而且該方法需要指定Startup檔案。這樣又繞回來了,想精簡卻被微軟的設計繞圈子了。

 

 

後面發現net6可以實現不需要startup檔案,net6程式碼上圖註釋部分。net6的program改動挺大,而且起步是WebApplication。通過檢視webapplication發現它的builder,webapplicationbuilder裡面是通過bootstrapHostBuilder指定了ConfigureWebHostDefaults的呼叫。

 

 

 

 net6可以精簡掉Startup檔案,但是它的啟動直接繫結了webhost,這裡跟net5比較連host都不能省了。

 

 

兜兜圈圈還是回到原點,因為沒有研究它的原始碼,所以只能瞭解到這裡了。最後兩個問題: 1. net6可否不帶host執行,2.IStartupFilter和Startup可否隔離host相互獨立,不要綁一起。

 

相關文章