Командлет Invoke-WmiMethod вызывает методы объектов инструментария управления Windows (WMI).
Новые командлеты Common Information Model (CIM), представленные в Windows PowerShell 3.0, выполняют те же задачи, что и командлеты WMI. Командлеты CIM соответствуют стандартам WS-Management (WSMan) и стандарту CIM, что позволяет командлетам использовать те же методы для управления компьютерами Windows и другими операционными системами. Вместо использования Invoke-WmiMethodрекомендуется использовать Invoke-CimMethod.
Примеры
Пример 1. Перечисление требуемого порядка параметров метода WMI
Эта команда перечисляет требуемый порядок объектов.
Эта команда запускает экземпляр Блокнота, вызвав метод Create класса Win32_Process.
Свойство returnValue заполняется 0, а свойство ProcessId заполняется целым числом (номером идентификатора следующего процесса), если команда завершена.
Эта команда переименовывает файл. Он использует параметр Path для ссылки на экземпляр класса CIM_DataFile. Затем он применяет метод Переименования к конкретному экземпляру.
Свойство ReturnValue заполняется 0, если команда завершена.
Пример 4. Передача массива значений с помощью "-ArgumentList"
Пример использования массива объектов $binSD за которым следует значение $null.
Задает параметры, передаваемые в вызываемой метод. Значение этого параметра должно быть массивом объектов, и они должны отображаться в порядке, необходимом для вызываемого метода. Командлет Invoke-CimCommand не имеет этих ограничений.
Чтобы определить порядок перечисления этих объектов, выполните метод GetMethodParameters() в классе WMI, как показано в примере 1, в конце этого раздела.
Это важно
Если первое значение является массивом, содержащим несколько элементов, требуется второе значение $null. В противном случае команда создает ошибку, например Unable to cast object of type 'System.Byte' to type 'System.Array'.. См. пример 4 выше.
Указывает, что этот командлет выполняет команду в качестве фонового задания. Используйте этот параметр для выполнения команд, которые занимают много времени.
При использовании параметра AsJob команда возвращает объект, представляющий фоновое задание, а затем отображает командную строку. Вы можете продолжать работать в сеансе, пока задание завершится. Если Invoke-WmiMethod используется для удаленного компьютера, задание создается на локальном компьютере, а результаты с удаленных компьютеров автоматически возвращаются на локальный компьютер. Чтобы управлять заданием, используйте командлеты, содержащие существительное Job (командлеты задания). Чтобы получить результаты задания, используйте командлет Receive-Job.
Чтобы использовать этот параметр с удаленными компьютерами, локальные и удаленные компьютеры должны быть настроены для удаленного взаимодействия. Кроме того, необходимо запустить Windows PowerShell с помощью параметра запуска от имени администратора в Windows Vista и более поздних версиях Windows. Дополнительные сведения см. в about_Remote_Requirements.
Указывает центр, используемый для проверки подлинности подключения WMI. Можно указать стандартную проверку подлинности Windows NT LAN Manager (NTLM) или Kerberos. Чтобы использовать NTLM, задайте для параметра центра значение ntlmdomain:<DomainName>, где <DomainName> определяет допустимое доменное имя NTLM. Чтобы использовать Kerberos, укажите kerberos:<DomainName>\<ServerName>. Параметр центра нельзя включить при подключении к локальному компьютеру.
Указывает в виде строкового массива компьютеры, на которые этот командлет выполняется команда. По умолчанию используется локальный компьютер.
Введите имя NetBIOS, IP-адрес или полное доменное имя одного или нескольких компьютеров. Чтобы указать локальный компьютер, введите имя компьютера, точку (.) или localhost.
Этот параметр не зависит от удаленного взаимодействия Windows PowerShell. Вы можете использовать параметр ComputerName, даже если компьютер не настроен для выполнения удаленных команд.
Указывает учетную запись пользователя, которая имеет разрешение на выполнение этого действия. По умолчанию используется текущий пользователь. Введите имя пользователя, например User01, Domain01\User01или [email protected]. Или введите объект PSCredential, например объект, возвращаемый командлетом Get-Credential. При вводе имени пользователя вам будет предложено ввести пароль.
Указывает объект ManagementObject, используемый в качестве входных данных. Если этот параметр используется, все остальные параметры, кроме Flag и Argument, игнорируются.
Задает предпочтительный языковой стандарт для объектов WMI. Укажите значение параметра языкового стандарта в качестве массива в формате MS_<LCID> в предпочтительном порядке.
Указывает путь объекта WMI класса WMI или указывает путь объекта WMI экземпляра класса WMI. Класс или указанный экземпляр должен содержать метод, указанный в параметре Name.
Задает значение регулирования для числа операций WMI, которые могут выполняться одновременно.
Этот параметр используется вместе с параметром AsJob. Ограничение регулирования применяется только к текущей команде, а не к сеансу или к компьютеру.
Этот командлет поддерживает общие параметры: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction и -WarningVariable. Дополнительные сведения см. в разделе about_CommonParameters.
Входные данные
None
Этот командлет не принимает входные данные.
Выходные данные
None
Этот командлет не создает выходные данные.
Примечания
Windows PowerShell включает следующие псевдонимы для Invoke-WmiMethod:
Источник этого содержимого можно найти на GitHub, где также можно создавать и просматривать проблемы и запросы на вытягивание. Дополнительные сведения см. в нашем руководстве для участников.