= 5.2.0, PHP 7, PHP 8)filter_var_array — 獲取多個變量并且過濾它們說明filter_var_array(array $data, mixed $definition = ?, bool $add_empty = ">

filter_var_array

(PHP 5 >= 5.2.0, PHP 7, PHP 8)

filter_var_array獲取多個變量并且過濾它們

說明

filter_var_array(array $data, mixed $definition = ?, bool $add_empty = true): mixed

不需要重復(fù)調(diào)用 filter_var() 就能獲取多個變量。

參數(shù)

data

數(shù)組,鍵為字符串,值為待過濾的數(shù)據(jù)。

definition

一個定義參數(shù)的數(shù)組。一個有效的鍵必須是一個包含變量名的string,一個有效的值要么是一個filter type,或者是一個array 指明了過濾器、標示和選項。如果值是一個數(shù)組,那么它的有效的鍵可以是 filter, 用于指明 filter type,flags 用于指明任何想要用于過濾器的標示,或者 options 用于指明任何想要用于過濾器的選項。 參考下面的例子來更好的理解這段說明。

這個參數(shù)也可以是一個filter constant的整數(shù)。那么數(shù)組中的所有值都會被這個過濾器所過濾。

add_empty

在返回值中添加 null 作為不存在的鍵。

返回值

如果成功則返回一個包含所請求變量的數(shù)組,或者當失敗時返回 false 。 一個數(shù)組的值如果過濾失敗則為 false ,或者為 null 如果變量不存在的話。

范例

示例 #1 一個 filter_var_array() 的例子

<?php
error_reporting
(E_ALL E_STRICT);
$data = array(
    
'product_id'    => 'libgd<script>',
    
'component'     => '10',
    
'versions'      => '2.0.33',
    
'testscalar'    => array('2''23''10''12'),
    
'testarray'     => '2',
);

$args = array(
    
'product_id'   => FILTER_SANITIZE_ENCODED,
    
'component'    => array('filter'    => FILTER_VALIDATE_INT,
                            
'flags'     => FILTER_FORCE_ARRAY
                            
'options'   => array('min_range' => 1'max_range' => 10)
                           ),
    
'versions'     => FILTER_SANITIZE_ENCODED,
    
'doesnotexist' => FILTER_VALIDATE_INT,
    
'testscalar'   => array(
                            
'filter' => FILTER_VALIDATE_INT,
                            
'flags'  => FILTER_REQUIRE_SCALAR,
                           ),
    
'testarray'    => array(
                            
'filter' => FILTER_VALIDATE_INT,
                            
'flags'  => FILTER_FORCE_ARRAY,
                           )

);

$myinputs filter_var_array($data$args);

var_dump($myinputs);
echo 
"\n";
?>

以上例程會輸出:

array(6) {
  ["product_id"]=>
  string(17) "libgd%3Cscript%3E"
  ["component"]=>
  array(1) {
    [0]=>
    int(10)
  }
  ["versions"]=>
  string(6) "2.0.33"
  ["doesnotexist"]=>
  NULL
  ["testscalar"]=>
  bool(false)
  ["testarray"]=>
  array(1) {
    [0]=>
    int(2)
  }
}

更新日志

版本 說明
5.4.0 添加 add_empty 參數(shù)。

參見