这里有一件事情可能让你惊讶,IWebHost接口没有被更新,它没有继承ASP.NET Core 3.0中的IHost。相似的,IWebHostBuilder也没有继承自IHostBuilder。它们依然是完全独立的接口, 一个只工作在ASP.NET Core中,一个只工作在通用主机中。
幸运的是,这也没有关系。现在ASP.NET Core 3.0已经被重构使用通用主机的抽象接口, 你可以编写使用通用主机IHostBuilder抽象的方法,并在ASP.NET Core和通用主机应用中共享它们。如果你需要进行ASP.NET Core的特定操作,你可以依然使用IWebHostBuilder接口。
例如,你可以编写如下的扩展方法,一个使用IHostBuilder, 一个使用IWebHostBuilder:
public static class ExampleExtensions { public static IHostBuilder DoSomethingGeneric(this IHostBuilder builder) { // 添加通用主机配置 return builder; } public static IWebHostBuilder DoSomethingWeb(this IWebHostBuilder builder) { // 添加Web托管配置 return builder; } }其中一个方法在通用主机上进行某些配置(列入,使用依赖注入注册某些服务),在另外一个方法中对IWebHostBuilder进行某种配置,例如你可能会为Kestrel服务器设置一些默认值。
如果你在创建了一个全新的ASP.NET Core 3.0应用,你的Program.cs文件看起来应该是如下代码:
public class Program { public static void Main(string[] args) => CreateHostBuilder(args).Build().Run(); public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => { webBuilder .UseStartup<Startup>(); }); }你可以添加针对两个扩展方法的调用。一个在通用IHostBuilder上调用,另一个在ConfigWebHostDefaults()方法中,针对IWebHostBuilder调用
public class Program { public static void Main(string[] args) => CreateHostBuilder(args).Build().Run(); public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .DoSomethingGeneric() // IHostBuilder扩展方法 .ConfigureWebHostDefaults(webBuilder => { webBuilder .DoSomethingWeb() // IWebHostBuilder扩展方法 .UseStartup<Startup>(); }); }在ASP.NET Core 3.0中,你可以对两种构建器类型进行调用,这意味着,你现在可以仅依赖通用主机的抽象,就可以在ASP.NET Core应用中复用它们。然后,你可以将ASP.NET Core的特性行为放在顶层,而不必像2.x中一样重复方法。
总结在本文中,我们讨论了ASP.NET Core 3.0中一些被标记为废弃的类型,它们被移动到哪里去了,以及这么做的原因。如果你正在将一个应用升级到ASP.NET Core 3.0, 你并不需要马上替换它们,因为他们现在的行为依然相同,但是在将来的版本中会被替换掉,因此如果可以的话,最好对其进行更新。在某些场景中,它还使你的应用之间共享代码更加容易,因此值得研究一下。