AspNetCore.Docs/aspnetcore/fundamentals/startup.md

6.9 KiB

title author description keywords ms.author manager ms.date ms.topic ms.assetid ms.technology ms.prod uid
Application Startup | Microsoft Docs ardalis ASP.NET Core, riande wpickett 10/14/2016 article 6538df00-4ec2-45e4-811a-d7ce2ee608ed aspnet aspnet-core fundamentals/startup

Application Startup

[!WARNING] This page documents version 1.0.0-rc1 and has not yet been updated for version 1.0.0

By Steve Smith

ASP.NET Core provides complete control of how individual requests are handled by your application. The Startup class is the entry point to the application, setting up configuration and wiring up services the application will use. Developers configure a request pipeline in the Startup class that is used to handle all requests made to the application.

The Startup class

In ASP.NET Core, the Startup class provides the entry point for an application, and is required for all applications. It's possible to have environment-specific startup classes and methods (see Working with Multiple Environments), but regardless, one Startup class will serve as the entry point for the application. ASP.NET searches the primary assembly for a class named Startup (in any namespace). You can specify a different assembly to search using the Hosting:Application configuration key. It doesn't matter whether the class is defined as public; ASP.NET will still load it if it conforms to the naming convention. If there are multiple Startup classes, this will not trigger an exception. ASP.NET will select one based on its namespace (matching the project's root namespace first, otherwise using the class in the alphabetically first namespace).

The Startup class can optionally accept dependencies in its constructor that are provided through dependency injection. Typically, the way an application will be configured is defined within its Startup class's constructor (see Configuration). The Startup class must define a Configure method, and may optionally also define a ConfigureServices method, which will be called when the application is started.

The Configure method

The Configure method is used to specify how the ASP.NET application will respond to individual HTTP requests. At its simplest, you can configure every request to receive the same response. However, most real-world applications require more functionality than this. More complex sets of pipeline configuration can be encapsulated in middleware and added using extension methods on IApplicationBuilder.

Your Configure method must accept an IApplicationBuilder parameter. Additional services, like IHostingEnvironment and ILoggerFactory may also be specified, in which case these services will be injected by the server if they are available. In the following example from the default web site template, you can see several extension methods are used to configure the pipeline with support for BrowserLink, error pages, static files, ASP.NET MVC, and Identity.

[!code-csharpMain]

Each Use extension method adds middleware to the request pipeline. For instance, the UseMvc extension method adds the routing middleware to the request pipeline and configures MVC as the default handler.

You can learn all about middleware and using IApplicationBuilder to define your request pipeline in the Middleware topic.

The ConfigureServices method

Your Startup class can optionally include a ConfigureServices method for configuring services that are used by your application. The ConfigureServices method is a public method on your Startup class that takes an IServiceCollection instance as a parameter and optionally returns an IServiceProvider. The ConfigureServices method is called before Configure. This is important, because some features like ASP.NET MVC require certain services to be added in ConfigureServices before they can be wired up to the request pipeline.

Just as with Configure, it is recommended that features that require substantial setup within ConfigureServices be wrapped up in extension methods on IServiceCollection. You can see in this example from the default web site template that several Add[Something] extension methods are used to configure the app to use services from Entity Framework, Identity, and MVC:

[!code-csharpMain]

Adding services to the services container makes them available within your application via dependency injection.

The ConfigureServices method is also where you should add configuration option classes that you would like to have available in your application. See the Configuration topic to learn more about configuring options.

Services Available in Startup

ASP.NET Core provides certain application services and objects during your application's startup. You can request certain sets of these services by simply including the appropriate interface as a parameter on your Startup class's constructor or one of its Configure or ConfigureServices methods. The services available to each method in the Startup class are described below. The framework services and objects include:

IApplicationBuilder

Used to build the application request pipeline. Available only to the Configure method in Startup. Learn more about Request Features.

IHostingEnvironment

Provides the current EnvironmentName, ContentRootPath, WebRootPath, and web root file provider. Available to the Startup constructor and Configure method.

ILoggerFactory

Provides a mechanism for creating loggers. Available to the Startup constructor and Configure method. Learn more about Logging.

IServiceCollection

The current set of services configured in the container. Available only to the ConfigureServices method, and used by that method to configure the services available to an application.

Looking at each method in the Startup class in the order in which they are called, the following services may be requested as parameters:

Startup Constructor - IHostingEnvironment - ILoggerFactory

ConfigureServices - IServiceCollection

Configure - IApplicationBuilder - IHostingEnvironment - ILoggerFactory

[!NOTE] Although ILoggerFactory is available in the constructor, it is typically configured in the Configure method. Learn more about Logging.

Additional Resources