ip2long

(PHP 4, PHP 5)

ip2long --  (IPv4) インターネットプロトコルドット表記のアドレスを適当なアドレ スを有する文字列に変換する

説明

int ip2long ( string ip_address )

関数 ip2long() は、インターネット標準形式 (ドット表記の文字列)表現から IPv4 インターネットネットアドレスを 生成します。ip_address が不正な形式の場合は -1 を返します。PHP では -1FALSE は等価ではないことに注意してください。

注意: PHP 5.0.0 では、ip2long()ip_address が不正な形式の場合に FALSE を返します。

例 1. ip2long() Example

<?php
$ip
= gethostbyname('www.example.com');
$out = "以下の URL は同じ意味です:<br />\n";
$out .= 'http://www.example.com/, http://' . $ip . '/, and http://' . sprintf("%u", ip2long($ip)) . "/<br />\n";
echo
$out;
?>

注意: PHP の整数型は符号付き形式であり、多くの IP アドレスは負の整数値に なります。そのため、符号なし IP アドレスを文字列形式で取得するには sprintf()printf() で "%u" を使用する必要があります。

2 番目の例は、printf() 関数で変換されたアドレスを 出力する方法を示すものです。PHP 4 と PHP 5 のどちらでも使えます。

例 2. IP アドレスの表示

<?php
$ip   
= gethostbyname('www.example.com');
$long = ip2long($ip);

if (
$long == -1 || $long === FALSE) {
    echo
'Invalid IP, please try again';
} else {
    echo
$ip   . "\n";           // 192.0.34.166
    
echo $long . "\n";           // -1073732954
    
printf("%u\n", ip2long($ip)); // 3221234342
}
?>

ip2long() を、それ単体で IP の検証に 利用するべきではありません。long2ip() と組み合わせて利用します。

例 3. IP の検証

<?php
// IP が有効であることを確認します。また、不完全な形式の IP を
// 以下で示すような正しい形式(ドットで 4 つに区切られている)に変換します。
$ip = long2ip(ip2long("127.0.0.1")); // "127.0.0.1"
$ip = long2ip(ip2long("10.0.0")); // "10.0.0.0"
$ip = long2ip(ip2long("10.0.256")); // "10.0.1.0"
?>

ip2long() は不完全な形式の IP アドレスに対しても 動作します。詳しい情報は http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/libs/commtrf2/inet_addr.htm を参照ください。

注意: PHP 5 <= 5.0.2 では、IP 255.255.255.255 に対して ip2long()FALSE を返します。 これは PHP 5.0.3 で -1 を返すように修正されています (PHP 4 と同じ動作です)。

long2ip() および sprintf() も参照ください。