ip2long
    (PHP 4, PHP 5)
ip2long -- 
     (IPv4) インターネットプロトコルドット表記のアドレスを適当なアドレ
     スを有する文字列に変換する
    
説明
int 
ip2long ( string ip_address )
     関数 ip2long() は、インターネット標準形式
     (ドット表記の文字列)表現から IPv4 インターネットネットアドレスを
     生成します。ip_address が不正な形式の場合は
     -1 を返します。PHP では -1
     と FALSE は等価ではないことに注意してください。
    
注意: 
      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() も参照ください。