PHP 進階過濾器

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.runoob.com";
 
 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 濾鏡參考手冊 來檢視濾鏡的特定應用。

參考手冊中包含了篩選器參數的簡要說明和使用範例!


繼續學習
||
<?php $str = "<h1>Hello WorldÆØÅ!</h1>"; $newstr = filter_var($str, FILTER_SANITIZE_STRING, FILTER_FLAG_STRIP_HIGH); echo $newstr; ?>