2012-04-03 4 views
0

Я пишу код для завершения определенных процессов через определенное время. Я использую следующий код (упрощенный для должности):Процесс завершения требует 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, которая необходима в наборе результатов?

спасибо!

ответ

4

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

В этом случае для Win32_Process класса WMI Путь объекта WMI выглядит Win32_Process.Handle="8112", так как вы видите Handle свойство является частью пути объекта Wmi и должен быть включен в вашем WQL sentece,

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

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(); 
     } 
    } 
} 
+0

так вы говорите: «SELECT Handle, Name, CreationDate» - это то, что нужно? – mdelvecchio

+0

Я только что протестировал - да, просто добавление Handle к WQL допускает завершение. благодаря! – mdelvecchio