PHPでのIPアドレス範囲チェックのご相談です。
以下のような範囲で行いたいと思います。
「192.168.0.1〜192.168.0.254」
以下のサイトを参考に、コードを組んでみました。
https://qiita.com/ran/items/039706c93a8ff85a011a
PHP
1<?php 2$accept = '192.168.0.1/24'; 3$remote_ip = '192.168.0.255'; 4 5list($accept_ip, $mask) = explode('/', $accept); 6$accept_long = ip2long($accept_ip) >> (32 - $mask); 7$remote_long = ip2long($remote_ip) >> (32 - $mask); 8if ($accept_long == $remote_long) { 9 echo 'acceptable'; 10} else { 11 echo 'not acceptable'; 12}
ただこれはビット判定な手前、失敗でした。
今回のような範囲ですと、どういう対応が適切でしょうか?
試したもの
1つ目(ただの範囲判定)
PHP
1$remote_ip = '192.168.0.0'; 2if ($remote_ip >= "192.168.0.1" && $remote_ip <= "192.168.0.254"){ 3 echo 'acceptable'; 4} else { 5 echo 'not acceptable'; 6}
2つ目("."で分解して末尾をrange、上3つをイコール)
PHP
1$remote_ip = '192.168.0.0'; 2$ipList = explode(".",$remote_ip); 3if(implode(".",array($ipList[0],$ipList[1],$ipList[2])) == "192.168.0" && 4in_array($ipList[3],range('1','254'))){ 5 echo 'acceptable'; 6} else { 7 echo 'not acceptable'; 8}
2つ目は思いつきで作ってみたところなんですが、分解したのにまた繋げて判定はちょっと悩ましかったです。
上のどっちが、や他に手頃な関数対応方法、可読性の観点でこう、など頂ければ幸いに思います。
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。