In the old days of web applications, things were simple—if you wanted a page, you had to have a physical one. However, things have since evolved and ASP.NET Core is now an MVC framework. What does that mean? Well, in MVC, there are no such thing as physical pages (although this is not exactly true);instead, it uses routing to directrequeststo routehandlers. The most common routehandlers in MVC arecontroller actions. After this chapter, you will learn how to use routing to access your controller actions.
A request is just some relative URL, such as this:
This results in more readable URLs, and is also advantageous for search engines such as Google. The subject of optimizing a site—including its public URLs—for search engines is called Search Engine Optimization (SEO).
When ASP.NET Core receives a request, one of the following two things can happen:
There is a physical file that matches the request.
There is a route that accepts the request.
In order for ASP.NET Core to serve physical files, it needs to be configured—for that, we use the UseStaticFiles extension method in Configure, which adds the static files, processing middleware to the pipeline; the call to UseStaticFiles is included in the Visual Studio template for ASP.NET Core web applications. If we don't enable static file serving, or if no file exists, the requests need to be handled by a route handler. The most common route handler in MVC is a controlleraction.
A controller is a class that exposes an action that knows how to process a request. An action is a method that may take parameters and returns an action result. A routing table is what we use to direct requests to controlleractions.
There are two APIs that we can use to register routes:
Fluent API (code)
Attributes
In previous versions, we had to explicitly add support for routing attributes, but they are now first-class citizens of .NET Core. Let's go through them, starting with the routing table concept.