77 lines
5.8 KiB
ReStructuredText
77 lines
5.8 KiB
ReStructuredText
Controllers, Actions, and Action Results
|
|
========================================
|
|
|
|
By `Steve Smith`_
|
|
|
|
Actions and action results are a fundamental part of how developers build apps using ASP.NET MVC.
|
|
|
|
Sections:
|
|
- `What is a Controller`_
|
|
- `Defining Actions`_
|
|
|
|
What is a Controller
|
|
--------------------
|
|
|
|
In ASP.NET MVC, a `Controller` is used to define and group a set of actions. An `action` (or `action method`) is a method on a controller that handles incoming requests. Controllers provide a logical means of grouping similar actions together, allowing common sets of rules (e.g. routing, caching, authorization) to be applied collectively. Incoming requests are mapped to actions through :doc:`routing <routing>`.
|
|
|
|
In ASP.NET 5, a controller can be any instantiable class that ends in "Controller" or inherits from a class that ends with "Controller". Controllers should follow the `Explicit Dependencies Principle <http://deviq.com/explicit-dependencies-principle>`_ and request any dependencies their actions require through their constructor using :doc:`dependency injection <dependency-injection>`.
|
|
|
|
By convention, controller classes:
|
|
* are located in the root-level "Controllers" folder
|
|
* inhert from Microsoft.AspNet.Mvc.Controller
|
|
|
|
These two conventions are not required.
|
|
|
|
Within the Model-View-Controller pattern, a Controller is responsible for the initial processing of the request and instantiation of the Model. Generally, business decisions should be performed within the Model.
|
|
|
|
.. note:: The Model should be a `Plain Old CLR Object (POCO)`, not a ``DbContext`` or database-related type.
|
|
|
|
The controller takes the result of the model's processing (if any), returns the proper view along with the associated view data. Learn more: :doc:`/mvc/overview` and :doc:`/tutorials/first-mvc-app/start-mvc`.
|
|
|
|
.. tip:: The Controller is a `UI level` abstraction. Its responsibility is to ensure incoming request data is valid and to choose which view (or result for an API) should be returned. In well-factored apps it will not directly include data access or business logic, but instead will delegate to services handling these responsibilities.
|
|
|
|
Defining Actions
|
|
----------------
|
|
Any public method on a controller type is an action. Parameters on actions are bound to request data and validated using :doc:`model binding </mvc/models/model-binding>`.
|
|
|
|
.. warning:: Action methods that accept parameters should verify the ``ModelState.IsValid`` property is true.
|
|
|
|
Action methods should contain logic for mapping an incoming request to a business concern. Business concerns should typically be represented as services that your controller accesses through :doc:`dependency injection <dependency-injection>`. Actions then map the result of the business action to an application state.
|
|
|
|
Actions can return anything, but frequently will return an instance of ``IActionResult`` (or ``Task<IActionResult>`` for async methods) that produces a response. The action method is responsible for choosing `what kind of response`; the action result `does the responding`.
|
|
|
|
Controller Helper Methods
|
|
#########################
|
|
|
|
Although not required, most developers will want to have their controllers inherit from the base ``Controller`` class. Doing so provides controllers with access to many properties and helpful methods, including the following helper methods designed to assist in returning various responses:
|
|
|
|
:doc:`View </mvc/views/index>`
|
|
Returns a view that uses a model to render HTML. Example: ``return View(customer);``
|
|
|
|
HTTP Status Code
|
|
Return an HTTP status code. Example: ``return BadRequest();``
|
|
|
|
Formatted Response
|
|
Return ``Json`` or similar to format an object in a specific manner. Example: ``return Json(customer);``
|
|
|
|
Content negotiated response
|
|
Instead of returning an object directly, an action can return a content negotiated response (using ``Ok``, ``Created``, ``CreatedAtRoute`` or ``CreatedAtAction``). Examples: ``return Ok();`` or ``return CreatedAtRoute("routename",values,newobject");``
|
|
|
|
Redirect
|
|
Returns a redirect to another action or destination (using ``Redirect``,``LocalRedirect``,``RedirectToAction`` or ``RedirectToRoute``). Example: ``return RedirectToAction("Complete", new {id = 123});``
|
|
|
|
In addition to the methods above, an action can also simply return an object. In this case, the object will be formatted based on the client's request. Learn more about :doc:`/mvc/models/formatting`
|
|
|
|
Cross-Cutting Concerns
|
|
######################
|
|
|
|
In most apps, many actions will share parts of their workflow. For instance, most of an app might be available only to authenticated users, or might benefit from caching. When you want to perform some logic before or after an action method runs, you can use a `filter`. You can help keep your actions from growing too large by using :doc:`filters` to handle these cross-cutting concerns. This can help eliminate duplication within your actions, allowing them to follow the `Don't Repeat Yourself (DRY) principle <http://deviq.com/don-t-repeat-yourself/>`_.
|
|
|
|
In the case of authorization and authentication, you can apply the ``Authorize`` attribute to any actions that require it. Adding it to a controller will apply it to all actions within that controller. Adding this attribute will ensure the appropriate filter is applied to any request for this action. Some attributes can be applied at both controller and action levels to provide granular control over filter behavior. Learn more: :doc:`filters` and :doc:`/security/authorization/authorization-filters`.
|
|
|
|
Other examples of cross-cutting concerns in MVC apps may include:
|
|
* :doc:`error-handling`
|
|
* :doc:`/performance/caching/response`
|
|
|
|
.. note:: Many cross-cutting concerns can be handled using filters in MVC apps. Another option to keep in mind that is available to any ASP.NET app is `custom middleware <https://docs.asp.net/en/latest/fundamentals/middleware.html>`_.
|