- Modern Web Development with ASP.NET Core 3
- Ricardo Peres
- 375字
- 2021-06-18 18:36:01
Finding controllers
Regardless of whether you go for POCO or non-POCO controllers, ASP.NET Core will apply the same rules for discovering controllers, which are as follows:
- They need to have the Controller suffix (strictly speaking, this can be changed, but we will leave this for now).
- They need to be instantiable classes (nonabstract, nongeneric, and nonstatic).
- They cannot have the [NonController] attribute applied to them.
- If they are POCO and do not have the Controller suffix, you can decorate them with the [Controller] attribute.
Controller classes are looked up by the name in the route—the controller parameter—and they are searched in the assemblies registered for that purpose. By default, the currently executing assembly is included in the search, but all assemblies registered as application parts are too. You can register additional application parts when you add the MVC features to the dependency injection framework (ConfigureServices method) as follows:
services.AddMvc()
.AddApplicationPart(typeof(MyCustomComponent).GetTypeInfo().Assembly);
Here, we are adding a reference to the assembly that contains a hypothetical class, MyCustomComponent. After we do this, any controllers that are located in it are available for use. In order to get the full list of found controllers, we can use ControllerFeature and populate it through ApplicationPartManager:
services.AddMvc()
.AddApplicationPart(typeof(MyCustomComponent).GetTypeInfo().Assembly)
.ConfigureApplicationPartManager(parts =>
{
var controllerFeature = new ControllerFeature();
parts.PopulateFeature(controllerFeature);
//controllerFeature.Controllers contains the list of discovered
//controllers' types
});
Controllers are only discovered once, at startup time, which is a good thing performance-wise.
If there are two controllers with the same name but that are in different namespaces, and they both expose an action method that matches the current request, then ASP.NET won't know which one to pick and will throw an exception. If this happens, we need to give one of the classes a new controller name by applying a [ControllerName] attribute, as shown in the following code:
namespace Controllers
{
public class HomeController
{
}
namespace Admin
{
[ControllerName("AdminHome")]
public class HomeController
{
}
}
}
We could also change the action name, as we will see in a moment. Now, let's see what happens once the controller type has been found.
- Python快樂編程:人工智能深度學習基礎
- Android項目開發入門教程
- 程序員面試算法寶典
- 程序員數學:用Python學透線性代數和微積分
- Clojure for Domain:specific Languages
- Visual Basic程序設計
- Terraform:多云、混合云環境下實現基礎設施即代碼(第2版)
- RESTful Java Web Services(Second Edition)
- Visual Basic程序設計習題與上機實踐
- SQL Server 2016 從入門到實戰(視頻教學版)
- Windows Phone 8 Game Development
- AI自動化測試:技術原理、平臺搭建與工程實踐
- Android智能手機APP界面設計實戰教程
- Python計算機視覺與深度學習實戰
- Head First Kotlin程序設計