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

filter_input_array

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

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

說明

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

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

參數(shù)

type

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

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 ,如果variable_name 不存在的話則返回 null 。 如果標示 FILTER_NULL_ON_FAILURE 被使用了,那么當變量不存在時返回 false ,當過濾失敗時返回 null 。

范例

示例 #1 一個 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";
?>

以上例程會輸出:

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ù).

注釋

注意:

INPUT_SERVER 數(shù)組中并沒有 REQUEST_TIME ,因為它是被稍后插入到$_SERVER 中的。

參見