= 5.2.0, PHP 7, PHP 8)filter_input_array — 獲取一系列外部變量,并且可以通過過濾器處理它們說(shuō)明filter_input_array(int $type, mixed $definition = ?, boo">

filter_input_array

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

filter_input_array獲取一系列外部變量,并且可以通過過濾器處理它們

說(shuō)明

filter_input_array(int $type, mixed $definition = ?, bool $add_empty = true): mixed

這個(gè)函數(shù)當(dāng)需要獲取很多變量卻不想重復(fù)調(diào)用filter_input()時(shí)很有用。

參數(shù)

type

INPUT_GET, INPUT_POST, INPUT_COOKIE, INPUT_SERVER, or INPUT_ENV之一。

definition

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

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

add_empty

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

返回值

如果成功的話返回一個(gè)所請(qǐng)求的變量的數(shù)組,如果失敗的話返回 false 。對(duì)于數(shù)組的值,如果過濾失敗則返回 false ,如果variable_name 不存在的話則返回 null 。 如果標(biāo)示 FILTER_NULL_ON_FAILURE 被使用了,那么當(dāng)變量不存在時(shí)返回 false ,當(dāng)過濾失敗時(shí)返回 null 。

范例

示例 #1 一個(gè) filter_input_array() 的例子

<?php
error_reporting
(E_ALL E_STRICT);
/* data actually came from POST
$_POST = 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_REQUIRE_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_REQUIRE_ARRAY,
                           )

);

$myinputs filter_input_array(INPUT_POST$args);

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

以上例程會(huì)輸出:

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)
  }
}

更新日志

版本 說(shuō)明
5.4.0 添加 add_empty 參數(shù).

注釋

注意:

INPUT_SERVER 數(shù)組中并沒有 REQUEST_TIME ,因?yàn)樗潜簧院蟛迦氲?var class="varname">$_SERVER 中的。

參見