Used By
| Used By | Description | 
|---|---|
| wp-includes/class-wp-http-streams.php: WP_Http_Streams::request() | Send a HTTP request to a URI using PHP Streams. | 
Decodes chunk transfer-encoding, based off the HTTP 1.1 specification.
Based off the HTTP http_encoding_dechunk function.
(string) (Required) Body content.
(string) Chunked decoded body on success or raw body on failure.
File: wp-includes/class-http.php
public static function chunkTransferDecode( $body ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.MethodNameInvalid
		// The body is not chunked encoded or is malformed.
		if ( ! preg_match( '/^([0-9a-f]+)[^\r\n]*\r\n/i', trim( $body ) ) ) {
			return $body;
		}
		$parsed_body = '';
		// We'll be altering $body, so need a backup in case of error.
		$body_original = $body;
		while ( true ) {
			$has_chunk = (bool) preg_match( '/^([0-9a-f]+)[^\r\n]*\r\n/i', $body, $match );
			if ( ! $has_chunk || empty( $match[1] ) ) {
				return $body_original;
			}
			$length       = hexdec( $match[1] );
			$chunk_length = strlen( $match[0] );
			// Parse out the chunk of data.
			$parsed_body .= substr( $body, $chunk_length, $length );
			// Remove the chunk from the raw data.
			$body = substr( $body, $length + $chunk_length );
			// End of the document.
			if ( '0' === trim( $body ) ) {
				return $parsed_body;
			}
		}
	}  | Version | Description | 
|---|---|
| 2.7.0 | Introduced. | 
    © 2003–2019 WordPress Foundation
Licensed under the GNU GPLv2+ License.
    https://developer.wordpress.org/reference/classes/wp_http/chunktransferdecode