PHP 新手入門進(jìn)階過(guò)濾器
偵測(cè)一個(gè)數(shù)字是否在一個(gè)範(fàn)圍內(nèi)
以下實(shí)例使用了filter_var() 函數(shù)來(lái)偵測(cè)一個(gè)INT 類型的變數(shù)是否在1 到200 內(nèi):
<?php header("Content-type: text/html; charset=utf-8");//設(shè)置編碼 $int = 122; $min = 1; $max = 200; if (filter_var($int, FILTER_VALIDATE_INT, array("options" => array("min_range"=>$min, "max_range"=>$max))) === false) { echo("變量值不在合法范圍內(nèi)"); } else { echo("變量值在合法范圍內(nèi)"); } ?>
偵測(cè)IPv6 位址
#以下實(shí)例使用了filter_var() 函數(shù)來(lái)偵測(cè)一個(gè)$ip 變數(shù)是否為IPv6 位址:
<?php header("Content-type: text/html; charset=utf-8");//設(shè)置編碼 $ip = "2001:0db8:85a3:08d3:1319:8a2e:0370:7334"; if (!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6) === false) { echo("$ip 是一個(gè) IPv6 地址"); } else { echo("$ip 不是一個(gè) IPv6 地址"); } ?>
偵測(cè)URL - 必須包含QUERY_STRING(查詢字串)
以下實(shí)例使用了filter_var() 函數(shù)來(lái)偵測(cè)$url 是否包含查詢字符字串:
<?php header("Content-type: text/html; charset=utf-8");//設(shè)置編碼 $url = "http://www.baidu11.com.cn"; if (!filter_var($url, FILTER_VALIDATE_URL, FILTER_FLAG_QUERY_REQUIRED) === false) { echo("$url 是一個(gè)合法的 URL"); } else { echo("$url 不是一個(gè)合法的 URL"); } ?>
移除ASCII 值大於127 的字元
以下實(shí)例使用了filter_var() 函數(shù)來(lái)移除字串中ASCII值大於127 的字符,同樣它也能移除HTML 標(biāo)籤:
<?php $str = "<h1>Hello World???!</h1>"; $newstr = filter_var($str, FILTER_SANITIZE_STRING, FILTER_FLAG_STRIP_HIGH); echo $newstr; ?>