завершение процесса требует WQL SELECT *?

я пишу код для завершения определенных процессов через определенное время. я использую приведенный ниже код (упрощенный для публикации):

ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT Name, CreationDate FROM Win32_Process WHERE Name = 'foo'"); 

foreach (ManagementObject process in searcher.Get())
{
    process.InvokeMethod("Terminate", null);
}

проблема - использование оператора WQL SELECT Name, CreationDate вызывает исключение при попытке выполнить завершение:

"Operation is not valid due to the current state of the object."

... но использование SELECT * работает и завершает процесс. почему это -- есть ли в наборе результатов определенный столбец WMI?

Благодарность!


person mdelvecchio    schedule 03.04.2012    source источник


Ответы (1)


Когда вы выполняете метод WMI, WMI выполняет внутренний поиск Путь к объекту WMI для идентификации экземпляра метода будет выполнен.

В этом случае для Win32_Process< /a> класс WMI, путь к объекту WMI выглядит как Win32_Process.Handle="8112". Как вы видите, свойство Handle является частью пути к объекту WMi и должно быть включено в ваше предложение WQL,

Проверьте этот образец.

using System;
using System.Collections.Generic;
using System.Management;
using System.Text;
//this will all the notepad running instances

namespace GetWMI_Info
{
    class Program
    {

        static void Main(string[] args)
        {
            try
            {
                string ComputerName = "localhost";
                ManagementScope Scope;                

                if (!ComputerName.Equals("localhost", StringComparison.OrdinalIgnoreCase)) 
                {
                    ConnectionOptions Conn = new ConnectionOptions();
                    Conn.Username  = "";
                    Conn.Password  = "";
                    Conn.Authority = "ntlmdomain:DOMAIN";
                    Scope = new ManagementScope(String.Format("\\\\{0}\\root\\CIMV2", ComputerName), Conn);
                }
                else
                    Scope = new ManagementScope(String.Format("\\\\{0}\\root\\CIMV2", ComputerName), null);

                Scope.Connect();
                ObjectQuery Query = new ObjectQuery("SELECT Handle FROM Win32_Process Where Name='notepad.exe'");
                ManagementObjectSearcher Searcher = new ManagementObjectSearcher(Scope, Query);

                foreach (ManagementObject WmiObject in Searcher.Get())
                {
                    WmiObject.InvokeMethod("Terminate", null);

                }
            }
            catch (Exception e)
            {
                Console.WriteLine(String.Format("Exception {0} Trace {1}",e.Message,e.StackTrace));
            }
            Console.WriteLine("Press Enter to exit");
            Console.Read();
        }
    }
}
person RRUZ    schedule 03.04.2012
comment
так вы говорите, что SELECT Handle, Name, CreationDate - это то, что нужно? - person mdelvecchio; 05.04.2012
comment
я только что проверил - да, простое добавление дескриптора в WQL включает завершение. Благодарность! - person mdelvecchio; 05.04.2012