Я пытаюсь получить доступ к MS Graph с помощью учетной записи AAD, эта учетная запись является глобальным администратором и имеет все права делегирования. Я хочу сделать это без интерактивного входа, используя UserPasswordCredential
. При попытке получить доступ к MS Graph Я получаю ошибку:Ошибка проверки доступа к токену MS Graph с использованием UserCredentials
Мой поток:
Получение токена:
public async Task<string> GetUserAccessTokenAsync()
{
UserPasswordCredential userPasswordCredential = new UserPasswordCredential("[email protected]", "password");
AuthenticationContext authContext = new AuthenticationContext("https://login.microsoftonline.com/tenant.onmicrosoft.com");
AuthenticationResult token = await authContext.AcquireTokenAsync("https://graph.windows.net", appId, userPasswordCredential);
return token.AccessToken;
}
с помощью маркера:
public static GraphServiceClient GetAuthenticatedClient()
{
GraphServiceClient graphClient = new GraphServiceClient(
new DelegateAuthenticationProvider(
async (requestMessage) =>
{
Adal adal = new Adal();
string accessToken = await adal.GetUserAccessTokenAsync();
// Append the access token to the request.
requestMessage.Headers.Authorization = new AuthenticationHeaderValue("bearer", accessToken);
}));
return graphClient;
}
Попытка позвонить MS Graph для чтения событий:
try
{
// Get events.
items = await eventsService.GetMyEvents(graphClient);
}
catch (ServiceException se)
{
//this is where I get the error
}
Любые идеи, где я неправильно?
Господин ... Иногда я удивляюсь даже самому себе. Спасибо за это, никогда бы не заметили. –
Я опечатал ресурс URI в примере кода, теперь он исправлен. – juunas