Литмир - Электронная Библиотека
A
A

Когда маршруты добавляются на уровне контроллера, методы действий получают этот базовый маршрут. Например, следующий маршрут контроллера охватывает

Delete()
и любые другие методы действий:

<b>[Route(&quot;[controller]/[action]/{id?}&quot;)]</b>

public class CarController : Controller

{

  public IActionResult Delete(int id)

  {

    ...

  }

}

На заметку! При маршрутизации с помощью атрибутов встроенные маркеры помечаются квадратными скобками (

[]
), а не фигурными (
{}
), как при маршрутизации на основе соглашений. Для специальных маркеров применяются все те же фигурные скобки.

Если методу действия необходимо перезапустить шаблон маршрута, тогда нужно предварить маршрут символом прямой косой черты (

/
). Скажем, если метод
Delete()
должен следовать шаблону URL вида
mysite.eom/Delete/Car/5
, то вот как понадобится сконфигурировать действие:

[Route(&quot;[controller]/[action]/{id?}&quot;)]

public class CarController : Controller

{

<b>  [Route(&quot;/[action]/[controller]/{id}&quot;)]</b>

   public IActionResult Delete(int id)

  {

    ...

  }

}

В маршрутах также можно жестко кодировать значения маршрутов вместо замены маркеров. Показанный ниже код даст тот же самый результат, как и предыдущий:

[Route(&quot;[controller]/[action]/{id?}&quot;)]

public class CarController : Controller

{

<b>  [Route(&quot;/Delete/Car/{id}&quot;)]</b>

  public IActionResult Delete(int id)

  {

    ...

  }

}

Именованные маршруты

Маршрутам можно также назначать имена, что обеспечит сокращение для перенаправления по определенному маршруту с указанием только его имени. Например, следующий атрибут маршрута имеет имя

GetOrderDetails
:

[HttpGet(&quot;{orderId}&quot;, Name = &quot;GetOrderDetails&quot;)]

Маршрутизация и методы HTTP

Вы могли заметить, что ни в одном определении шаблона маршрута для методов не присутствует какой-нибудь метод HTTP. Причина в том, что механизм маршрутизации (в приложениях MVC и API) для выбора надлежащей конечной точки приложения использует шаблон маршрута и метод HTTP совместно.

Методы HTTP при маршрутизации в веб-приложениях (MVC)

Довольно часто при построении веб-приложений с применением паттерна MVC соответствовать определенному шаблону маршрута будут две конечные точки приложения. Средством различения в таких ситуациях является метод HTTP. Скажем, если

CarController
содержит два метода действий с именем
Delete()
и они оба соответствуют шаблону маршрута, то выбор метода для выполнения основывается на методе HTTP, который используется в запросе. Первый метод
Delete()
декорируется атрибутом
HttpGet
и будет выполняться, когда входящим запросом является
GET
. Второй метод
Delete()
декорируется атрибутом
HttpPost
и будет выполняться, когда входящим запросом является
POST
:

[Route(&quot;[controller]/[action]/{id?}&quot;)]

public class CarController : Controller

{

<b>  [HttpGet]</b>

  public IActionResult Delete(int id)

  {

    ...

  }

<b>  [HttpPost]</b>

  public IActionResult Delete(int id, Car recordToDelete)

  {

    ...

  }

}

Маршруты можно модифицировать также с применением атрибутов методов HTTP, а не атрибута

Route
. Например, ниже показан необязательный маркер маршрута
id
, добавленный в шаблон маршрута для обоих методов
Delete()
:

[Route(&quot;[controller]/[action] &quot;)]

public class CarController : Controller

{

  [HttpGet<b>(&quot;{id?}</b>&quot;)]

  public IActionResult Delete(int? id)

  {

    ...

  }

  [HttpPost<b>(&quot;{id}</b>&quot;)]

  public IActionResult Delete(int id, Car recordToDelete)

  {

    ...

  }

}

Маршруты можно перезапускать с использованием методов HTTP; понадобится просто предварить шаблон маршрута символом прямой косой черты (

/
), как демонстрируется в следующем примере:

[HttpGet<b>(&quot;/[controller]/[action]/{makeId}/{makeName}&quot;)</b>]

580
{"b":"847442","o":1}