Поделиться через


Настройка клиента службы Microsoft Graph SDK

Клиент пакета SDK Microsoft Graph настраивает набор ПО промежуточного слоя по умолчанию, который позволяет пакету SDK взаимодействовать с конечными точками Microsoft Graph. Этот настраиваемый набор по умолчанию позволяет изменять поведение клиента. Например, можно вставить настраиваемое ведение журнала или обработчик теста для имитации конкретных сценариев. Вы можете добавлять и удалять компоненты ПО промежуточного слоя. Важно отметить, что порядок, в котором выполняются компоненты ПО промежуточного слоя, имеет большое значение.

// tokenCredential is one of the credential classes from Azure.Identity
// scopes is an array of permission scope strings
var authProvider = new AzureIdentityAuthenticationProvider(tokenCredential, isCaeEnabled: true, scopes: scopes);

var handlers = GraphClientFactory.CreateDefaultHandlers();

// ChaosHandler simulates random server failures
// Microsoft.Kiota.Http.HttpClientLibrary.Middleware.ChaosHandler
handlers.Add(new ChaosHandler());

var httpClient = GraphClientFactory.Create(handlers);
var customGraphClient = new GraphServiceClient(httpClient, authProvider);

Настройка прокси-сервера HTTP для клиента

В некоторых средах клиентские приложения должны использовать прокси-сервер HTTP перед доступом к общедоступному Интернету. В этом разделе показано, как настроить прокси-сервер для пакетов SDK Microsoft Graph.

// URI to proxy
var proxyAddress = "http://localhost:8888";

// Create an HttpClientHandler with the proxy to
// pass to the Azure.Identity token credential
var handler = new HttpClientHandler
{
    Proxy = new WebProxy(proxyAddress),
};

// Create an options object that corresponds to the
// token credential being used. For example, this sample
// uses a ClientSecretCredential, so the corresponding
// options object is ClientSecretCredentialOptions
var options = new ClientSecretCredentialOptions()
{
    Transport = new HttpClientTransport(handler),
};

var tokenCredential = new ClientSecretCredential(
    "YOUR_TENANT_ID",
    "YOUR_CLIENT_ID",
    "YOUR_CLIENT_SECRET",
    options);

// NOTE: Authentication requests will not go through the proxy.
// Azure.Identity token credential classes have their own separate method
// for configuring a proxy using TokenCredentialOptions.Transport
var authProvider = new AzureIdentityAuthenticationProvider(tokenCredential, isCaeEnabled: true, scopes: scopes);

// This example works with Microsoft.Graph 5+
// Use the GraphClientFactory to create an HttpClient with the proxy
var httpClient = GraphClientFactory.Create(proxy: new WebProxy(proxyAddress));
var graphClient = new GraphServiceClient(httpClient, authProvider);