Я никогда полностью не изучал асинхронное программирование.У меня есть этот метод:
internal static Task gpUpdate(string pcName, string localUser, string localPass)
{
return Task.Run(() =>
{
string result = "";
string command = @"/C psexec \\" + pcName + " /accepteula -s Gpupdate.exe /force";
// string command = "/C winrs -r:" + pcName + " ECHO ON&echo N|Gpupdate.exe /force";
Process process = new Process();
process.StartInfo.UseShellExecute = false;
process.StartInfo.StandardOutputEncoding = Encoding.GetEncoding(CultureInfo.CurrentCulture.TextInfo.OEMCodePage);
process.StartInfo.RedirectStandardOutput = true;
process.StartInfo.FileName = "CMD.exe";
process.StartInfo.WorkingDirectory = @"C:\Windows\System32";
process.StartInfo.Arguments = command;
process.StartInfo.UserName = Credentials.username;
process.StartInfo.Password = Credentials.securePassword;
process.StartInfo.Domain = "EPCE001N";
process.Start();
var output = process.StandardOutput.ReadToEnd();
if (output.Contains("Aktualizace zásady uživatele byla úspěšně dokončena."))
{
result = result + Environment.NewLine + pcName + " user GP update success...";
}
else
{
result = result + Environment.NewLine + pcName + " user GP update failed...";
}
if (output.Contains("Aktualizace zásady počítače byla úspěšně dokončena."))
{
result = result + Environment.NewLine + pcName + " computer GP update success...";
}
else
{
result = result + Environment.NewLine + pcName + " computer GP update failed...";
}
PSEXEC.output = PSEXEC.output + Environment.NewLine + result;
});
}
, и я называю его так:
private async void gpUpdateBtn_Click(object sender, RoutedEventArgs e)
{
List<Task> tasks = new List<Task>();
foreach (var pc in pcNamesListBox.Items)
{
tasks.Add(PSEXEC.gpUpdate(pc.ToString(), lclUsernameTxtBox.Text, lclPasswordTxtBox.Password));
}
Task.WaitAll(tasks.ToArray());
textBlock.Text = PSEXEC.output;
}
, но пользовательский интерфейс все еще зависает, и я не смог сделать эту работу в течение последних 2,5ч.Может кто-нибудь разобраться в этом, пожалуйста?