Выбери любимый жанр
Мир литературы

Выбрать книгу по жанру

Фантастика и фэнтези

Детективы и триллеры

Проза

Любовные романы

Приключения

Детские

Поэзия и драматургия

Старинная литература

Научно-образовательная

Компьютеры и интернет

Справочная литература

Документальная литература

Религия и духовность

Юмор

Дом и семья

Деловая литература

Жанр не определен

Техника

Прочее

Драматургия

Фольклор

Военное дело

Последние комментарии
Сергей2018-11-27
Не книга, а полная чушь! Хорошо, что чит
К книге
Lynxlynx2018-11-27
Читать такие книги полезно для расширени
К книге
Leonika2016-11-07
Есть аналоги и покрасивее...
К книге
Важник2018-11-27
Какое-то смутное ощущение после прочтени
К книге
Aida2018-11-27
Не книга, а полная чушь! Хорошо, что чит
К книге

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю - Страница 606


606
Изменить размер шрифта:

Оставшиеся контроллеры

Все оставшиеся контроллеры, специфичные для сущностей, будут производными от класса

BaseCrudController
, но без добавления дополнительной функциональности. Добавьте в каталог
Controllers
еще четыре пустых контроллера API с именами
CreditRisksController
,
CustomersController
,
MakesController
и
OrdersController
.

Вот код оставшихся контроллеров:

// CreditRisksController.cs

using AutoLot.Api.Controllers.Base;

using AutoLot.Models.Entities;

using AutoLot.Dal.Repos.Interfaces;

using AutoLot.Services.Logging;

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

using Microsoft.AspNetCore.Mvc;

namespace AutoLot.Api.Controllers

{

  [Route("api/[controller]")]

  public class CreditRisksController

    : BaseCrudController<CreditRisk, CreditRisksController>

  {

    public CreditRisksController(

      ICreditRiskRepo creditRiskRepo, IAppLogging<CreditRisksController> logger)

      : base(creditRiskRepo, logger)

    {

    }

  }

}

// CustomersController.cs

using AutoLot.Api.Controllers.Base;

using AutoLot.Models.Entities;

using AutoLot.Dal.Repos.Interfaces;

using AutoLot.Services.Logging;

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

using Microsoft.AspNetCore.Mvc;

namespace AutoLot.Api.Controllers

{

  [Route("api/[controller]")]

  public class CustomersController : BaseCrudController<Customer, CustomersController>

  {

    public CustomersController(

      ICustomerRepo customerRepo, IAppLogging<CustomersController> logger)

      : base(customerRepo, logger)

    {

    }

  }

}

// MakesController.cs

using AutoLot.Api.Controllers.Base;

using AutoLot.Models.Entities;

using Microsoft.AspNetCore.Mvc;

using AutoLot.Dal.Repos.Interfaces;

using AutoLot.Services.Logging;

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

namespace AutoLot.Api.Controllers

{

  [Route("api/[controller]")]

  public class MakesController : BaseCrudController<Make, MakesController>

  {

    public MakesController(IMakeRepo makeRepo, IAppLogging<MakesController> logger)

      : base(makeRepo, logger)

    {

    }

  }

}

// OrdersController.cs

using AutoLot.Api.Controllers.Base;

using AutoLot.Dal.Repos.Interfaces;

using AutoLot.Models.Entities;

using AutoLot.Services.Logging;

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

using Microsoft.AspNetCore.Mvc;

namespace AutoLot.Api.Controllers

{

  [Route("api/[controller]")]

  public class OrdersController : BaseCrudController<Order, OrdersController>

  {

     public OrdersController(IOrderRepo orderRepo,

       IAppLogging<OrdersController> logger) :
base(orderRepo, logger)

    {

    }

  }

}

Итак, все контроллеры готовы и вы можете с помощью пользовательского интерфейса Swagger протестировать полную функциональность. Если вы собираетесь добавлять/обновлять/удалять записи, тогда измените значение

RebuildDataBase
на
true
в файле
appsettings.development.json
:

{

  ...

<b>  &quot;RebuildDataBase&quot;: true,</b>

  ...

}

Фильтры исключений

Когда в приложении Web API возникает исключение, никакая страница со сведениями об ошибке не отображается, т.к. пользователем обычно является другое приложение, а не человек. Информация об ошибке должна быть отправлена в формате JSON наряду с кодом состояния HTTP. Как обсуждалось в главе 29, инфраструктура ASP.NET Core позволяет создавать фильтры, которые запускаются при появлении необработанных исключений. Фильтры можно применять глобально, на уровне контроллера или на уровне действия. Для текущего приложения вы построите фильтр исключений для отправки данных JSON (вместе с кодом HTTP 500) и включения трассировки стека, если сайт функционирует в режиме отладки.