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

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

這個函式當需要獲取很多變數卻不想重複呼叫filter_input()時很有用。

參數

type

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

definition

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

這個參數也可以是一個filter constant的整數。那麼陣列中的所有變數都會被這個過濾器所過濾。

add_empty

在返回值中新增 null 作為不存在的鍵。

返回值

如果成功的話返回一個所請求的變數的陣列,如果失敗的話返回 false 。對於陣列的值,如果過濾失敗則返回 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 參數.

註釋

注意:

INPUT_SERVER 陣列中並沒有 REQUEST_TIME ,因為它是被稍後插入到$_SERVER 中的。

參見

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *