PHP開(kāi)發(fā)基礎(chǔ)教學(xué)進(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 $int = 134; $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)"); } ?>
#輸出見(jiàn)右圖
二、偵測(cè)IPv6 位址
以下實(shí)例使用了filter_var() 函數(shù)來(lái)偵測(cè)一個(gè)$ip 變數(shù)是否是IPv6 位址:
<?php $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 地址"); } ?>輸出見(jiàn)右圖
三、偵測(cè)URL - 必須包含QUERY_STRING(查詢(xún)字串)
以下實(shí)例使用了filter_var() 函數(shù)來(lái)偵測(cè)$url 是否包含查詢(xún)字串:#程式碼如下<?php $url = "http://www.miracleart.cn"; if (!filter_var($url, FILTER_VALIDATE_URL, FILTER_FLAG_QUERY_REQUIRED) === false) { echo("$url 是一個(gè)合法的 URL"); } else { echo("$url 不是一個(gè)合法的 URL"); } ?>輸出結(jié)果見(jiàn)右圖
四、移除ASCII 值大於127 的字元
##。除ASCII 值大於127 的字元
<?php $str = "<h1>Hello World???!</h1>"; $newstr = filter_var($str, FILTER_SANITIZE_STRING, FILTER_FLAG_STRIP_HIGH); echo $newstr; ?>###輸出結(jié)果見(jiàn)右圖#########註:更多PHP 濾鏡的應(yīng)用請(qǐng)查看PHP手冊(cè)# ########?#############