PHP 進階過濾器
偵測一個數字是否在一個範圍內
以下實例使用了filter_var() 函數來偵測一個INT 類型的變數是否在 1 到200 內:
實例
<?php $int = 122; $min = 1; $max = 200; if (filter_var($int, FILTER_VALIDATE_INT, array("options" => array("min_range"=>$min, "max_range"=>$max))) === false) { echo("变量值不在合法范围内"); } else { echo("变量值在合法范围内"); } ?>
運行實例»
點擊"運行實例" 按鈕查看線上實例
偵測IPv6 位址
以下實例使用了filter_var() 函數來偵測一個$ip 變數是否是 IPv6 位址:
實例
<?php $ip = "2001:0db8:85a3:08d3:1319:8a2e:0370:7334"; if (!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6) === false) { echo("$ip 是一个 IPv6 地址"); } else { echo("$ip 不是一个 IPv6 地址"); } ?>
#執行實例»
點擊"執行實例" 按鈕可查看線上實例
偵測URL - 必須包含QUERY_STRING(查詢字串)
以下實例使用了filter_var() 函數來偵測$url 是否包含查詢字串:
#實例
<?php $url = "http://www.php.cn"; if (!filter_var($url, FILTER_VALIDATE_URL, FILTER_FLAG_QUERY_REQUIRED) === false) { echo("$url 是一个合法的 URL"); } else { echo("$url 不是一个合法的 URL"); } ?>
運行實例»
#點擊"運行實例" 按鈕查看線上實例
移除ASCII 值大於127 的字元
以下實例使用了filter_var() 函數來移除字串中ASCII 值大於127 的字符,同樣它也能移除HTML 標籤:
實例
<?php $str = "<h1>Hello WorldÆØÅ!</h1>"; $newstr = filter_var($str, FILTER_SANITIZE_STRING, FILTER_FLAG_STRIP_HIGH); echo $newstr; ?>
運行實例»
#點擊"運行實例" 按鈕查看線上實例
PHP 過濾器參考手冊
你也可以透過存取本站的PHP 過濾器參考手冊 來查看過濾器的具體應用。
參考手冊中包含了篩選器參數的簡要說明和使用範例!