Startup 类配置服务和应用的请求管道。

Startup 类

Startup 类:

  • ApplicationServices 在整个应用中使用服务 。
  • 包括 Configure 方法以创建应用的请求处理管道。

在应用启动时,ASP.NET Core 运行时会调用 ConfigureServices 和 Configure

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }
 
    public IConfiguration Configuration { get; }
 
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddRazorPages();
    }
 
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/Error");
            app.UseHsts();
        }
 
        app.UseHttpsRedirection();
        app.UseStaticFiles();
 
        app.UseRouting();
 
        app.UseAuthorization();
 
        app.UseEndpoints(endpoints =>
        {
            endpoints.MapRazorPages();
        });
    }
}

通常通过在主机生成器上调用 WebHostBuilderExtensions.UseStartup<TStartup> 方法来指定 Startup 类:

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>();
            });
}

主机和应用服务都可以在 Configure 和整个应用中使用。

使用泛型主机 (IHostBuilder) 时,只能将以下服务类型注入 Startup 构造函数:

  • IWebHostEnvironment
  • IHostEnvironment
  • IConfiguration
    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>();
                });
    }

    ConfigureServices 方法

    ConfigureServices 方法:

    • 可选。
    • 在 Configure 方法配置应用服务之前,由主机调用。
    • 配置选项。

    主机。

    例如,AddDbContext、AddDefaultIdentity、AddEntityFrameworkStores 和 AddRazorPages:

    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }
     
        public IConfiguration Configuration { get; }
     
        public void ConfigureServices(IServiceCollection services)
        {
     
            services.AddDbContext<ApplicationDbContext>(options =>
                options.UseSqlServer(
                    Configuration.GetConnectionString("DefaultConnection")));
            services.AddDefaultIdentity<IdentityUser>(
                options => options.SignIn.RequireConfirmedAccount = true)
                .AddEntityFrameworkStores<ApplicationDbContext>();
     
            services.AddRazorPages();
        }

    服务通过依赖关系注入或 ApplicationServices 进行解析。

    Configure 方法

    托管创建 IApplicationBuilder 并将其直接传递到 Configure

    ASP.NET Core 模板配置的管道支持:

    • 开发人员异常页
    • 异常处理程序
    • HTTP 严格传输安全性 (HSTS)
    • HTTPS 重定向
    • 静态文件
    • ASP.NET Core MVC 和 Razor Pages
      public class Startup
      {
          public Startup(IConfiguration configuration)
          {
              Configuration = configuration;
          }
       
          public IConfiguration Configuration { get; }
       
          public void ConfigureServices(IServiceCollection services)
          {
              services.AddRazorPages();
          }
       
          public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
          {
              if (env.IsDevelopment())
              {
                  app.UseDeveloperExceptionPage();
              }
              else
              {
                  app.UseExceptionHandler("/Error");
                  app.UseHsts();
              }
       
              app.UseHttpsRedirection();
              app.UseStaticFiles();
       
              app.UseRouting();
       
              app.UseAuthorization();
       
              app.UseEndpoints(endpoints =>
              {
                  endpoints.MapRazorPages();
              });
          }
      }

      例如,UseStaticFiles 配置中间件提供静态文件。

      请求管道中的每个中间件组件负责调用管道中的下一个组件,或在适当情况下使链发生短路。

      如果这些服务可用,则会被注入。

      ASP.NET Core 中间件。

相关文章:

  • 2018-12-10
  • 2021-01-14
  • 2019-07-23
  • 2022-01-23
  • 2022-12-23
  • 2021-05-30
  • 2021-08-10
  • 2021-10-12
猜你喜欢
  • 2022-12-23
  • 2021-08-16
  • 2021-10-18
  • 2022-12-23
  • 2021-04-04
  • 2021-05-26
相关资源
相似解决方案