PHP 進階過濾器LOGIN

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://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 $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 地址"); } ?>
章節課件