SNMP::get
SNMP オブジェクトを取得する
説明
public mixed SNMP::get(arraystring $objectId
, bool $preserveKeys
= false
)
パラメータ
objectId
が文字列の場合は SNMP::get
は SNMP オブジェクトを文字列で返します。
objectId
が配列の場合は、要求されたすべての SNMP
オブジェクトを SNMP オブジェクトの id とその値の連想配列で返します。
-
objectId
-
SNMP オブジェクト (OID)。
-
preserveKeys
-
objectId
が配列のときに
preserveKeys
を true
にすると、結果のキーは完全に objectId
となります。
それ以外の場合は SNMP::oid_output_format
プロパティを使ってキーの形式を判断します。
戻り値
objectId
で指定した
SNMP オブジェクトの値を
objectId
にあわせて文字列か配列で返します。
エラー時には false
を返します。
エラー / 例外
このメソッドは、デフォルトでは一切例外をスローしません。ライブラリでエラーが発生したときに
SNMPException をスローさせるには SNMP クラスパラメータ
exceptions_enabled
に値を設定しなければなりません。
詳細は
SNMP::$exceptions_enabled
の説明を参照ください。
例
例1 単一の SNMP オブジェクト
ひとつの SNMP オブジェクトに対するリクエストは二通りの方法で行えます。
文字列でリクエストすると結果は文字列で返され、要素がひとつだけの配列でリクエストすると結果は連想配列で返されます。
<?php
$session = new SNMP(SNMP::VERSION_1, "127.0.0.1", "public");
$sysdescr = $session->get("sysDescr.0");
echo "$sysdescr\n";
$sysdescr = $session->get(array("sysDescr.0"));
print_r($sysdescr);
?>
STRING: Test server
Array
(
[SNMPv2-MIB::sysDescr.0] => STRING: Test server
)
例2 複数の SNMP オブジェクト
$session = new SNMP(SNMP::VERSION_1, "127.0.0.1", "public");
$results = $session->get(array("sysDescr.0", "sysName.0"));
print_r($results);
$session->close();
Array
(
[SNMPv2-MIB::sysDescr.0] => STRING: Test server
[SNMPv2-MIB::sysName.0] => STRING: myhost.nodomain
)
参考
- SNMP::getErrno
- SNMP::getError