Я звоню azure API управления, чтобы получить список экземпляров в облачной службе.
Следующий код работает, когда fiddler активен, и постоянно возвращает 401 неавторизованным, когда он не проходит через fiddler.
Я не могу определить причину. Без Fiddler токен возвращается правильно, поэтому я не понимаю, почему я получаю несанкционированный доступ.
private HostedService GetCloudServiceProperties(string serviceName)
{
if (_client == null)
{
GetClient();
}
string serviceProperties = string.Format("https://management.core.windows.net/{0}/services/hostedservices/{1}?embed-detail=true", AzureSettings.SubscriptionId, serviceName);
var result = _client.GetStringAsync(serviceProperties).Result;
var serializer = new XmlSerializer(typeof(HostedService), "http://schemas.microsoft.com/windowsazure");
var returnValue = (HostedService)serializer.Deserialize(new StringReader(result));
return returnValue;
}
private void GetClient()
{
string authority = "https://login.microsoftonline.com/" + AzureSettings.TenantName;
IConfidentialClientApplication app;
app = ConfidentialClientApplicationBuilder.Create(AzureSettings.ClientId)
.WithClientSecret(AzureSettings.ClientSecret)
.WithAuthority(new Uri(authority))
.Build();
List<string> scopes = new List<string>()
{
"https://management.core.windows.net/.default"
};
var token = app.AcquireTokenForClient(scopes).ExecuteAsync().Result;
_client = new HttpClient();
_client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
_client.DefaultRequestHeaders.Add("x-ms-version", "2009-10-01");
}