Startup 类

ASP.NET Core应用程序需要一个启动类,按照惯例命名为Startup。在主程序的Web Host生成器(WebHostBuilderExtensions)的 UseStartup 扩展方法中指定启动类名称。
您可以为不同的环境定义不同的Startup类,并在运行时选择适当的Startup类。如果在Web Host配置或选项中指定startupAssembly(启动程序集),托管将加载该启动程序集并搜索 Startup 或 Startup[Environment] 类型。根据名称后缀匹配当前环境的类将被优先使用,所以如果应用程序在开发环境中运行,并包含一个Startup和一个StartupDevelopment类,他将使用StartupDevelopment类。

通俗的讲,ASP.NET

Core应用程序启动的时候将会根据当前的运行环境(生产环境(Production)或者开发环境(Development))自动选择启动类。比如在一个ASP.NET

Core应用程序中,具有两个启动类Startup和StartupDevelopment,那么当我们的启动环境设置为开发环境的时候,启动时将会搜索启动程序集,优先使用StartupDevelopment这个带有Development后缀的启动类。

我们来验证一下!
建立两个启动类Startup和StartupDevelopment,我们分别在这两个类的构造方法中打上标记以便于我们区分使用了哪个启动类。
Startup:
ASP.NET Core 应用程序Startup类介绍 - 图1
StartupDevelopment:
ASP.NET Core 应用程序Startup类介绍 - 图2
然后在Program类中设置启动程序集名称
ASP.NET Core 应用程序Startup类介绍 - 图3
我们通过修改launchSettings.json里的环境配置来切换环境:
ASP.NET Core 应用程序Startup类介绍 - 图4
我们可以看到当我们使用开发环境的时候使用的确实是StartupDevelopment启动类。
我们也可以通过调用UseStartup来定义一个固定的Startup类,该类将被使用而不考虑环境。 这是推荐的方法。
Startup类构造方法可以接受通过依赖注入提供的依赖性。 常用的方法是使用IHostingEnvironment来设置配置源。
Startup类必须包含Configure方法,并可以选择包含ConfigureServices方法,这两个方法在应用程序启动时调用。 该类还可以包含这些方法的特定于环境的版本。 ConfigureServices(如果存在)在Configure之前调用。

Configure方法主要是配置ASP.NET Core的中间件,相当于我们在ASP.NET中所说的管道,ConfigureServices主要是配置依赖注入(DI)。

ConfigureServices 方法

ConfigureServices方法是可选的; 但是如果使用的话,它会在WebHost的Configure方法之前被调用。 WebHost可能会在调用启动方法之前配置一些服务。 按照惯例,在这个方法中设置配置选项。
对于需要大量设置的功能,在IServiceCollection上添加Add[Service]扩展方法。 下面示例将应用程序配置为使用Entity Framework,Identity和MVC的服务:

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. // Add framework services.
  4. services.AddDbContext<ApplicationDbContext>(options =>
  5. options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
  6. services.AddIdentity<ApplicationUser, IdentityRole>()
  7. .AddEntityFrameworkStores<ApplicationDbContext>()
  8. .AddDefaultTokenProviders();
  9. services.AddMvc();
  10. // Add application services.
  11. services.AddTransient<IEmailSender, AuthMessageSender>();
  12. services.AddTransient<ISmsSender, AuthMessageSender>();
  13. }

将服务添加到服务容器使得它们可以通过依赖注入在应用程序中使用

在启动时可用的服务

ASP.NET Core依赖注入在应用程序启动期间提供服务。 您可以通过在Startup类的构造方法或其Configure方法中包含适当的接口作为参数来请求这些服务。 ConfigureServices方法只接受一个IServiceCollection参数(但是可以从这个集合中检索任何已注册的服务,所以不需要额外的参数)。
下面是一些通常由启动方法请求的服务:

  • 在构造方法中:IHostingEnvironment,ILogger
  • 在ConfigureServices方法中:IServiceCollection
  • 在Configure方法中:IApplicationBuilder, IHostingEnvironment, ILoggerFactory

Startup类构造方法或其Configure方法可以请求由WebHostBuilder ConfigureServices方法添加的任何服务。 使用WebHostBuilder在启动方法中提供您需要的任何服务。

Configure 方法

Configure方法用于指定ASP.NET应用程序如何响应HTTP请求。 通过将中间件组件添加到由依赖注入提供的IApplicationBuilder实例来配置请求管道。
从下面的例子中,我们使用了几个扩展方法来配置支持BrowserLink,error pages, static files, ASP.NET MVC, 和 Identity的管道。

  1. public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
  2. {
  3. loggerFactory.AddConsole(Configuration.GetSection("Logging"));
  4. loggerFactory.AddDebug();
  5. if (env.IsDevelopment())
  6. {
  7. app.UseDeveloperExceptionPage();
  8. app.UseDatabaseErrorPage();
  9. app.UseBrowserLink();
  10. }
  11. else
  12. {
  13. app.UseExceptionHandler("/Home/Error");
  14. }
  15. app.UseStaticFiles();
  16. app.UseIdentity();
  17. app.UseMvc(routes =>
  18. {
  19. routes.MapRoute(
  20. name: "default",
  21. template: "{controller=Home}/{action=Index}/{id?}");
  22. });
  23. }

每个Use扩展方法将一个中间件组件添加到请求管道。 例如,UseMvc扩展方法将路由中间件添加到请求管道,并将MVC配置为默认处理程序。
有关如何使用IApplicationBuilder的更多信息,请参阅中间件。
额外的服务,如IHostingEnvironment和ILoggerFactory也可以在方法签名中指定,在这种情况下,如果这些服务可用,将被注入。