Категории
Самые читаемые
onlinekniga.com » Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

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

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

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
Перейти на страницу:

namespace AutoLot.Services.ApiWrapper

{

  public interface IApiServiceWrapper

  {

    Task<IList<Car>> GetCarsAsync();

    Task<IList<Car>> GetCarsByMakeAsync(int id);

    Task<Car> GetCarAsync(int id);

    Task<Car> AddCarAsync(Car entity);

    Task<Car> UpdateCarAsync(int id, Car entity);

    Task DeleteCarAsync(int id, Car entity);

    Task<IList<Make>> GetMakesAsync();

  }

}

Класс ApiServiceWrapper

Создайте в каталоге ApiWrapper проекта AutoLot.Services новый файл класса по имени ApiServiceWrapper.cs и модифицируйте его операторы using следующим образом:

using System;

using System.Collections.Generic;

using System.Net.Http;

using System.Net.Http.Json;

using System.Text;

using System.Text.Json;

using System.Threading.Tasks;

using AutoLot.Models.Entities;

using Microsoft.Extensions.Options;

Сделайте класс открытым и добавьте конструктор, который принимает экземпляр HttpClient и экземпляр реализации IOptionsMonitor<ApiServiceSettings>. Создайте закрытую переменную типа ServiceSettings и присвойте ей значение с использованием свойства CurrentValue параметра IOptionsMonitor<Service Settings>. Код показан ниже:

public class ApiServiceWrapper : IApiServiceWrapper

{

  private readonly HttpClient _client;

  private readonly ApiServiceSettings _settings;

  public ApiServiceWrapper(<b>HttpClient client</b>,

      IOptionsMonitor&lt;ApiServiceSettings&gt; settings)

  {

      _settings = settings.CurrentValue;

    _client = client;

    _client/BaseAddress = new Uri(_settins.Uri);

  }

}

На заметку! В последующих разделах содержится много кода без какой-либо обработки ошибок. Поступать так настоятельно не рекомендуется! Обработка ошибок здесь опущена из-за экономии пространства.

Внутренние поддерживающие методы

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

Класс содержит четыре поддерживающих метода, которые применяются открытыми методами.

Вспомогательные методы для POST и PUT

Следующие методы являются оболочками для связанных методов HttpClient:

internal async Task&lt;HttpResponseMessage&gt; PostAsJson(string uri, string json)

{

  return await _client.PostAsync(uri, new StringContent(json, Encoding.UTF8,

                                 &quot;application/json&quot;));

}

internal async Task&lt;HttpResponseMessage&gt; PutAsJson(string uri, string json)

{

  return await _client.PutAsync(uri, new StringContent(json, Encoding.UTF8,

                                &quot;application/json&quot;));

}

Вспомогательный метод для DELETE

Последний вспомогательный метод используется для выполнения НТТР-метода DELETE. Спецификация HTTP 1.1 (и более поздние версии) позволяет передавать тело в HTTP-методе DELETE, но для этого пока еще не предусмотрено расширяющего метода HttpClient. Экземпляр HttpRequestMessage потребуется создавать с нуля.

Первым делом необходимо создать сообщение запроса с применением инициализации объектов для установки Content, Method и RequestUri. Затем сообщение отправляется, после чего ответ возвращается вызывающему коду. Вот код метода:

internal async Task&lt;HttpResponseMessage&gt; DeleteAsJson(string uri, string json)

{

  HttpRequestMessage request = new HttpRequestMessage

  {

    Content = new StringContent(json, Encoding.UTF8, &quot;application/json&quot;),

    Method = HttpMethod.Delete,

    RequestUri = new Uri(uri)

  };

  return await _client.SendAsync(request);

}

Вызовы HTTP-метода GET

Есть четыре вызова НТТР-метода GET: один для получения всех записей Car, один для получения записей Car по производителю Make, один для получения одиночной записи Car и один для получения всех записей Make. Все они следуют тому же самому шаблону. Метод GetAsync() вызывается для возвращения экземпляра HttpResponseMessage. Успешность или неудача вызова проверяется с помощью метода EnsureSuccessStatusCode(), который генерирует исключение, если вызов не возвратил код состояния успеха. Затем тело ответа сериализируется в тип свойства (сущность или список сущностей) и возвращается вызывающему коду. Ниже приведен код всех методов:

Перейти на страницу:
На этой странице вы можете бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю.
Комментарии