2017 © Pedro Peláez
 

library wmi

Biblioteca wmi para gerenciamento remoto de máquinas Windows

image

crphp/wmi

Biblioteca wmi para gerenciamento remoto de máquinas Windows

  • Tuesday, November 29, 2016
  • by fabiojaniolima
  • Repository
  • 0 Watchers
  • 1 Stars
  • 14 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 2 Forks
  • 1 Open issues
  • 4 Versions
  • 0 % Grown

The README.md

crphp/wmi

Está é uma biblioteca que faz uso do WQL (WMI Query Language) para manipulação do instrumento WMI em máquinas Windows. Em outras palavras, essa biblioteca permite o gerenciamento remoto de máquinas Windows, dispensando a instalação de agentes e plugins nas máquinas clientes., (*1)

Caso sua intenção seja somente consultar os recursos de uma máquina remota, recomendo fortemente que analise a possibilidade de utilizar crphp/wmic em razão da performance., (*2)

crphp/wmi e crphp/wmic possuem os mesmos recursos de consulta, porém, somente crphp/wmi tem a capacidade de gerenciar recursos remotos, como parar serviços, matar processos etc., (*3)

Está biblioteca segue os padrões descritos na PSR-2, logo, isso implica que a mesma está em conformidade com a PSR-1., (*4)

As palavras-chave "DEVE", "NÃO DEVE", "REQUER", "DEVERIA", "NÃO DEVERIA", "PODERIA", "NÃO PODERIA", "RECOMENDÁVEL", "PODE", e "OPCIONAL" neste documento devem ser interpretadas como descritas no RFC 2119. Tradução livre RFC 2119 pt-br., (*5)

  1. Referências
  2. Funcionalidades
  3. Requisitos (recomendados)
  4. Configurando o servidor
  5. Preparando a máquina cliente
  6. Baixando o pacote crphp/wmi para o servidor
  7. Exemplos de uso
  8. Licença (MIT)

1 - Referências

2 - Funcionalidades

  • [x] Consultar CPU
  • [x] Consultar RAM
  • [x] Consultar Disco Rígido
  • [x] Consultar serviço
  • [x] Listar Serviços
  • [x] Stop / Start de serviço
  • [x] Consultar processo
  • [x] Listar processos
  • [x] Alterar prioridade do processo
  • [x] Matar / Finalizar processos
  • [x] Transformação de timestamp Windows para data/hora
  • [ ] Lançar processos
  • [ ] Listar e matar sessões

3 - Preparando o servidor

:exclamation: Os requisitos sugeridos logo abaixo representam as versões utilizadas em nosso ambiente de desenvolvimento e produção, logo não garantimos que a solução aqui apresentada irá rodar integralmente caso as versões dos elementos abaixo sejam outras., (*6)

3.1 - Requisitos (recomendados)

Servidor - REQUER Windows (desktop >= Windows 7 ou Windows Server >= 2003) - REQUER Apache >= 2.4.10 - REQUER PHP >= 5.5.12, (*7)

Cliente - REQUER Windows (desktop >= Windows 7 ou Windows Server >= 2003) - NÃO REQUER a instalação de nenhum componente, (*8)

4 - Configurando o servidor

No arquivo php.ini DEVE ser adicionada alinha:, (*9)

extension=php_com_dotnet.dll

Você DEVE verificar se o arquivo php_com_dotnet.dll está presente no diretório php/ext, (*10)

5 - Preparando a máquina cliente

As configurações deste tópico DEVEM ser executadas em todas as máquinas alvos de gerenciamento remoto, ou seja, em todas as máquinas cliente., (*11)

5.1 - Liberando regra de firewall nos clientes

Caminho para as regras de firewall:, (*12)

Painel de Controle > Ferramentas Administrativas > Firewall do Windows com Segurança Avançada

Para permitir as conexões WMI teremos que habilitar as Regras de Entrada:, (*13)

Instrumentação de Gerenciamento do Windows (DCOM-In)
Instrumentação de Gerenciamento do Windows (WMI-In)

E as Regras de Saída:, (*14)

Instrumentação de Gerenciamento do Windows (WMI-Saída)

Para não ter problema, é RECOMENDÁVEL que o usuário de conexão remota tenha privilégio de administrador na máquina de destino. Obviamente você PODE configurar o contexto de acesso caso tenha alguma familiridade com este assunto., (*15)

6 - Baixando o pacote crphp/wmi para o servidor

Para a etapa abaixo estou pressupondo que você tenha o composer instalado e saiba utilizá-lo:, (*16)

composer require crphp/wmi

Ou se preferir criar um projeto:, (*17)

composer create-project --prefer-dist crphp/wmi nome_projeto

Caso ainda não tenha o composer instalado, obtenha este em: https://getcomposer.org/download/, (*18)

7 - Exemplos de uso

Consultar CPU:, (*19)

use Crphp\Wmi\Sistema\Cpu;
use Crphp\Wmi\Conector\Wmi;

$wmi = new Wmi;
$wmi->conectar('ip_ou_hostname', 'usuario', 'senha');

if($wmi->status()) {

    $cpu = new Cpu($wmi);
    echo "<pre>";
    print_r($cpu->detalhes());
    echo "</pre>";

} else {
    echo $wmi->mensagemErro();
}

Todas as demais classes funcionam praticamente da mesma forma., (*20)

Consultar Disco Rígido, (*21)

use Crphp\Wmi\Conector\Wmi;
use Crphp\Wmi\Sistema\DiscoRigido;

$wmi = new Wmi;
$wmi->conectar('ip_ou_hostname', 'usuario', 'senha');

if($wmi->status())
{
    // Letra de unidade opcional
    $obj = new DiscoRigido($wmi, "C");
    echo "

";
    print_r($obj->detalhes());
    echo "
"; } else { echo $wmi->mensagemErro(); }

Listar ou encerrar processo, (*22)

use Crphp\Wmi\Conector\Wmi;
use Crphp\Wmi\Sistema\Processos;

$wmi = new Wmi;
$wmi->conectar('ip_ou_hostname', 'usuario', 'senha');

if($wmi->status()) {
    $obj = new Processos($wmi);

    echo "<pre>";
    print_r($obj->detalhes());
    //print_r($obj->killProcesso());
    echo "</pre>";

} else {
    echo $wmi->mensagemErro();
}

Você DEVE sempre instânciar o conector Wmi e a classe referente ao elemento que deseja manipular, (*23)

Também é possível executar suas próprias consultas customizadas, (*24)

use Crphp\Wmi\Conector\Wmi;

$wmi = new Wmi;
$wmi->conectar('ip_ou_hostname', 'usuario', 'senha');

if($wmi->status()) {
    $memoria = $wmi->executar("select AvailableBytes from Win32_PerfRawData_PerfOS_Memory");
    // Será retornado um objeto em caso de sucesso ou uma string em caso de erro
} else {
    echo $wmi->mensagemErro();
}

8 - Licença (MIT)

Para maiores informações, leia o arquivo de licença disponibilizado junto desta biblioteca., (*25)

The Versions

29/11 2016

dev-master

9999999-dev

Biblioteca wmi para gerenciamento remoto de máquinas Windows

  Sources   Download

MIT

The Requires

 

by Fábio Jânio

wmi acesso remoto

26/11 2016

v1.1.2

1.1.2.0

Biblioteca wmi para gerenciamento remoto de máquinas Windows

  Sources   Download

MIT

The Requires

 

by Fábio Jânio

wmi acesso remoto

24/11 2016

v1.1.1

1.1.1.0

Biblioteca wmi para gerenciamento remoto de máquinas Windows

  Sources   Download

MIT

The Requires

 

by Fábio Jânio

wmi acesso remoto

23/11 2016

v1.0.0

1.0.0.0

Biblioteca wmi para gerenciamento remoto de máquinas Windows

  Sources   Download

MIT

The Requires

 

by Fábio Jânio

wmi acesso remoto