Como lidar com Configuration Manager erros assíncronos usando código gerenciado
Para lidar com um erro Configuration Manager gerado durante uma consulta assíncrona, teste a RunWorkerCompletedEventArgs
propriedade error exception do parâmetro que é passada para o manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted. Se Erro não null
for , ocorrerá uma exceção e você usará Erro para descobrir a causa.
Se Error for um SmsQueryException, você poderá usá-lo para chegar ao subjacente __ExtendedException
ou SMS_ExtendedException
. Como a biblioteca gerenciada do Provedor de SMS não encerra essas exceções, você precisará usar o objeto System.Management namespace ManagementException para acessá-las.
Para lidar com um erro de consulta assíncrono
Crie uma consulta assíncrona.
No manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted de consulta assíncrona, implemente o código no exemplo a seguir.
Execute a consulta assíncrona. Para testar o manipulador de exceção, passe uma cadeia de caracteres de consulta mal formada, como
Select & from &&&
para o método QueryProcessorBase.ProcessQuery .
Exemplo
O exemplo a seguir implementa um manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted .
Para obter informações sobre como chamar o código de exemplo, consulte Chamando Configuration Manager Snippets de Código.
void bw1_QueryProcessorCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error != null)
{
Console.WriteLine("There was an Error");
if (e.Error is SmsQueryException)
{
SmsQueryException queryException = (SmsQueryException)e.Error;
Console.WriteLine(queryException.Message);
// Get either the __ExtendedStatus or SMS_ExtendedStatus object and display various properties.
ManagementException mgmtExcept = queryException.InnerException as ManagementException;
if (mgmtExcept != null)
{
if (string.Equals(mgmtExcept.ErrorInformation.ClassPath.ToString(), "SMS_ExtendedStatus", StringComparison.OrdinalIgnoreCase) == true)
{
Console.WriteLine("Configuration Manager provider exception");
}
else if (string.Equals(mgmtExcept.ErrorInformation.ClassPath.ToString(), "__ExtendedStatus", StringComparison.OrdinalIgnoreCase) == true)
{
Console.WriteLine("WMI exception");
}
Console.WriteLine(mgmtExcept.ErrorCode.ToString());
Console.WriteLine(mgmtExcept.ErrorInformation["ParameterInfo"].ToString());
Console.WriteLine(mgmtExcept.ErrorInformation["Operation"].ToString());
Console.WriteLine(mgmtExcept.ErrorInformation["ProviderName"].ToString());
}
}
if (e.Error is SmsConnectionException)
{
Console.WriteLine("There was a connection error :" + ((SmsConnectionException)e.Error).Message);
Console.WriteLine(((SmsConnectionException)e.Error).ErrorCode);
}
}
Console.WriteLine("Done...");
}
O método de exemplo tem os seguintes parâmetros:
Parâmetro | Tipo | Descrição |
---|---|---|
sender |
- Object |
A origem do evento. |
e |
- RunWorkerCompletedEventArgs |
Os dados do evento. Para obter mais informações, consulte Classe RunWorkerCompletedEventArgs. |
Compilando o código
Este exemplo de C# requer:
Namespaces
System
System.Collections.Generic
System.Text
Microsoft. ConfigurationManagement.ManagementProvider
Microsoft. ConfigurationManagement.ManagementProvider.WqlQueryEngine
System.Management
System.ComponentModel
Assembly
microsoft.configurationmanagement.managementprovider
adminui.wqlqueryengine
System.Management
Programação robusta
Para obter mais informações sobre o tratamento de erros, consulte Sobre erros de Configuration Manager.