snmp2_set
(PHP >= 5.2.0, PHP 7, PHP 8)
snmp2_set — Set the value of an SNMP object
Descrição
snmp2_set
( string $hostname
, string $community
, array|string $object_id
, array|string $type
, array|string $value
, int $timeout
= -1
, int $retries
= -1
) : array|bool
Parâmetros
-
hostname
-
The hostname of the SNMP agent (server).
-
community
-
The write community.
-
object_id
-
The SNMP object id.
-
type
-
O MIB define o tipo de cada id de objeto. Pode ser um caractere da lista abaixo.
types
= | Lista de MIBs id |
i | INTEGER |
u | INTEGER |
s | STRING |
x | HEX STRING |
d | DECIMAL STRING |
n | NULLOBJ |
o | OBJID |
t | TIMETICKS |
a | IPADDRESS |
b | BITS |
Se OPAQUE_SPECIAL_TYPES
foi definido durante a compilação da biblioteca SNMP, os seguintes também são válidos:
types
U | unsigned int64 |
I | signed int64 |
F | float |
D | double |
A maioria dos tipos tem correspondentes óbvios com tipos ASN.1. 's', 'x', 'd' e 'b' são modos diferentes de especificar um valor OCTET STRING e
'u' também é utilizado para manipular valores Gauge32.
Se MIB-Files foi carregado na árvore MIB com "snmp_read_mib" ou por especificá-lo na configuração do libsnmp, '=' pode ser utilizado
como parâmetro type
para todos os identificadores de objeto que podem ser lidos automaticamente do MIB.
Note que há duas maneiras de configurar o tipo BITS, assim:
"SYNTAX BITS {telnet(0), ftp(1), http(2), icmp(3), snmp(4), ssh(5), https(6)}":
-
Utilizando "b" e uma lista de bits. Esse método não é recomendado desde que requisições GET para o mesmo OID pode retornar algo com 0xF8.
-
Utilizando "x" e um número hex sem (!) o prefixo "0x".
Veja a seção de exemplo para mais detalhes.
-
value
-
The new value.
-
timeout
-
The number of microseconds until the first timeout.
-
retries
-
The number of times to retry if timeouts occur.
Valor Retornado
Retorna true
em caso de sucesso ou false
em caso de falha.
If the SNMP host rejects the data type, an E_WARNING message like "Warning: Error in packet. Reason: (badValue) The value given has the wrong type or length." is shown.
If an unknown or invalid OID is specified the warning probably reads "Could not add variable".
Exemplos
Exemplo #1 Using snmp2_set()
<?php
snmp2_set("localhost", "public", "IF-MIB::ifAlias.3", "s", "foo");
?>
Exemplo #2 Using snmp2_set() for setting BITS SNMP object id
<?php
snmp2_set("localhost", "public", 'FOO-MIB::bar.42', 'b', '0 1 2 3 4');
// or
snmp2_set("localhost", "public", 'FOO-MIB::bar.42', 'x', 'F0');
?>