request_parse_body

Read and parse the request body and return the result

Description

array request_parse_body(arraynull $options = null)

This function reads the request body and parses it according to the Content-Type header. Currently, two content types are supported:

  • application/x-www-form-urlencoded
  • multipart/form-data

This function is used primarily to parse multipart/form-data requests with HTTP verbs other than POST which do not automatically populate the $_POST and $_FILES superglobals.

Caution

request_parse_body consumes the request body without buffering it to the php://input stream.

Parameters

options
The options parameter accepts an associative array to override the following global php.ini settings for parsing of the request body.
  • max_file_uploads
  • max_input_vars
  • max_multipart_body_parts
  • post_max_size
  • upload_max_filesize

Return Values

request_parse_body returns an array pair with the equivalent of $_POST at index 0 and $_FILES at index 1.

Errors/Exceptions

When the request body is invalid, according to the Content-Type header, a RequestParseBodyException is thrown.

A ValueError is thrown when options contains invalid keys, or invalid values for the corresponding key.

Examples

Example #1 request_parse_body example

<?php
// Parse request and store result in the $_POST and $_FILES superglobals.
[$_POST, $_FILES] = request_parse_body();
// Echo the content of some transferred file
echo file_get_contents($_FILES['file_name']['tmp_name']);
?>

Example #2 request_parse_body example with customized options

<?php
// form.php

assert_logged_in();

// Only for this form, we allow a bigger upload size.
[$_POST, $_FILES] = request_parse_body([
    'post_max_size' => '10M',
    'upload_max_filesize' => '10M',
]);

// Do something with the uploaded files.
?>