Google предоставляет клиентскую библиотеку .NET для взаимодействия с API Менеджера рекламы. Мы рекомендуем использовать клиентскую библиотеку с NuGet.
Для начала создайте новый проект в выбранной вами среде IDE или добавьте зависимость к существующему проекту. Google публикует артефакты клиентской библиотеки в репозитории NuGet как Google.Ads.AdManager.V1
.
Справочник пакетов
<!-- MyProject.csproj -->
<PackageReference Include="Google.Ads.AdManager.V1" Version="1.0.0-beta01" />
.NET интерфейс командной строки
dotnet add package Google.Ads.AdManager.V1 --version 1.0.0-beta01
Настройка учетных данных
Клиентская библиотека .NET использует OAuth2 и учетные данные приложения по умолчанию (ADC) для аутентификации.
ADC ищет учетные данные по порядку в следующих местах:
- Переменная среды
GOOGLE_APPLICATION_CREDENTIALS
. - Учетные данные пользователя, настроенные через Google Cloud CLI (gcloud CLI).
- При работе в Google Cloud учетная запись службы привязывается к ресурсу Google Cloud.
Для создания и настройки учетных данных ADC см. раздел Аутентификация .
Сделайте свой первый запрос
Каждая служба имеет объект ServiceClient
с синхронными и асинхронными методами для каждого метода REST. В следующем примере Network
считывается синхронно. Все сущности идентифицируются именем ресурса, состоящим из типа и числового идентификатора сущности.
using Google.Ads.AdManager.V1;
public sealed partial class GeneratedNetworkServiceClientSnippets
{
public void GetNetwork()
{
// Create client
NetworkServiceClient networkServiceClient = NetworkServiceClient.Create();
// Initialize request argument(s)
string name = "networks/[NETWORK_CODE]";
// Make the request
Network response = networkServiceClient.GetNetwork(name);
}
}
Примеры других методов и ресурсов см. в репозитории GitHub googleapis/google-cloud-dotnet
.
Обработка ошибок
Все ошибки API Менеджера рекламы имеют тип Grpc.Core.RpcException в клиентской библиотеке .NET.
Ошибки включают уникальный request_id
, который вы можете предоставить службе поддержки для помощи в устранении неполадок. В следующем примере извлекаются статус HTTP, сообщение об ошибке и request_id
.
using Google.Ads.AdManager.V1;
using Google.Api.Gax.Grpc;
using Google.Rpc;
using Grpc.Core;
try
{
NetworkServiceClient networkServiceClient = NetworkServiceClient.Create();
Network network = networkServiceClient.GetNetwork("networks/[NETWORK_CODE]");
}
catch(RpcException e)
{
// HTTP Status code
StatusCode statusCode = e.Status.StatusCode;
// Error message
string errorMessage = e.Status.Detail;
// Unique request identifier.
RequestInfo requestInfo = e.GetStatusDetail<RequestInfo>();
string requestId = requestInfo?.RequestId ?? "Unexpected null request identifier";
}
Создание имен ресурсов
Клиентская библиотека предоставляет вспомогательные классы для создания имен ресурсов на основе идентификаторов. Их можно передавать непосредственно в методы службы.
// Represents a resource name in the format:
// "networks/{networkCode}/orders/{orderId}"
OrderName name = OrderName.FromNetworkCodeOrder("123", "456");
Order response = orderServiceClient.GetOrder(name);