filter函數過濾ip地址的方法:
| 代碼如下 |
複製代碼 |
echo filter_var("127.0.0.1","FILTER_VALIDATE_INT"); //返回true or false |
例子。
判斷是否是合法IP
| 代碼如下 |
複製代碼 |
if(filter_var($ip, FILTER_VALIDATE_IP)) { // it's valid } else { // it's not valid } |
判斷是否是合法的公用IPv4地址,192.168.1.1這類的私人IP地址將會排除在外
| 代碼如下 |
複製代碼 |
if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4 | FILTER_FLAG_NO_PRIV_RANGE)) { // it's valid } else { // it's not valid } |
判斷是否是合法的IPv6地址
| 代碼如下 |
複製代碼 |
if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) { // it's valid } else { // it's not valid } |
判斷是否是public IPv4 IP或者是合法的Public IPv6 IP地址
| 代碼如下 |
複製代碼 |
if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE)) { // it's valid } else { // it's not valid } |
簡單的正則
preg_match("/d{1,3}.d{1,3}.d{1,3}.d{1,3}/");// 此方法沒不精確,學最大為255.255.255.255 但這個只是驗證格式了,如999.999.999.999也可以通過驗證。
我們進入升級改進
| 代碼如下 |
複製代碼 |
functionis_ip($gonten){ $ip=explode(”.”,$gonten); for($i=0;$i<count($ip);$i++) { if($ip[$i]>255){ return(0); } } return ereg(”^[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}$”,$gonten); } |
這樣就符合我們的要求了
再介紹一種用判斷ip地址:
| 代碼如下 |
複製代碼 |
function matchip($q){ preg_match('/((25[0-5])|(2[0-4]d)|(1dd)|([1-9]d)|d)(.((25[0-5])|(2[0-4]d)|(1dd)|([1-9]d)|d)){3}/', $q, $matches); return $matches[0]; }
$ipaddress = '201.103.2.2'; $iperror ='262.3.6.6'; $iptest = matchip( $ipaddress ); //當我們給matchip 的值為$ipaddress輸出為201.103.2.2 //當我們給matchip的函數值為$iperror時,輸出值為 62.3.6.6 if( $iptest ) { echo $iptest; } else { echo 'www.111cn.net提示:你輸的的ip地址有問題'; } |