PHP input stream php: // difference between input and POST/GET-PHP source code

Source: Internet
Author: User
Tags php print
Php: input is also a data submission method, but we seldom use php: input for data submission, so php: what is the difference between input and our common POSTGET data submission methods? Let's take a look at this article. Php: // input is also a data submission method, but we seldom use php: // input for data submission, so php: // What is the difference between input and our commonly used POST/GET data submission methods? Let's take a look at this article.

Script ec (2); script

PHP input stream php: // input
When using xml-rpc, the server obtains client data mainly through the php input stream input instead of the $ _ POST array. So here we will mainly discuss php input stream php: // input
For php: // input introduction, the PHP official manual provides a clear overview of it:

"Php: // input allows you to read raw POST data. it is a less memory intensive alternative to $ HTTP_RAW_POST_DATA and does not need any special php. ini directives. php: // input is not available with enctype = "multipart/form-data ".

The translation is like this:

"Php: // input can read POST data that has not been processed. Compared with $ HTTP_RAW_POST_DATA, it puts less pressure on memory and does not require special php. ini settings. Php: // input cannot be used for enctype = multipart/form-data"
How should we understand this overview? I divide it into three parts to gradually understand:

Read POST Data

Cannot be used for multipart/form-data Type
Php: // input VS $ HTTP_RAW_POST_DATA

Read POST Data

PHPer must be familiar with the built-in variable $ _ POST. $ _ What are the associations and differences between POST and php: // input? In addition, the most common method for the client to interact with the server is POST and GET. Since php: // input is used as the PHP input stream, can it read GET data? These two questions are what we need to discuss in this section.

Experience tells us that summing up from testing and observation will be a very useful method. Here, I wrote a few scripts to help us test.

@ File 192.168.0.6:/phpinput_server.php print the received data
@ File 192.168.0.8:/phpinput_post.php simulate submitting form data using the POST method
@ File 192.168.0.8:/phpinput_xmlrpc.php simulate the POST method to issue the xmlrpc request.
@ File 192.168.0.8:/phpinput_get.php simulate the number of tables submitted using the GET Method
Phpinput_server.php and phpinput_post.php

// @ File phpinput_server.php
$ Raw_post_data = file_get_contents ('php: // input', 'R ');
Echo "------- \ $ _ POST ------------------ \ n ";
Echo var_dump ($ _ POST). "\ n ";
Echo "------- php: // input ------------- \ n ";
Echo $ raw_post_data. "\ n ";
// @ File phpinput_post.php
$ Http_entity_body = 'n' = '. urldecode ('perfgeeks'). '& p ='. urldecode ('123 ');
$ Http_entity_type = 'application/x-www-form-urlencoded ';
$ Http_entity_length = strlen ($ http_entity_body );
$ Host = '1970. 168.0.6 ';
$ Port = 80;
$ Path = '/phpinput_server.php ';
$ Fp = fsockopen ($ host, $ port, $ error_no, $ error_desc, 30 );
If ($ fp ){
Fputs ($ fp, "POST {$ path} HTTP/1.1 \ r \ n ");
Fputs ($ fp, "Host: {$ host} \ r \ n ");
Fputs ($ fp, "Content-Type: {$ http_entity_type} \ r \ n ");
Fputs ($ fp, "Content-Length: {$ http_entity_length} \ r \ n ");
Fputs ($ fp, "Connection: close \ r \ n ");
Fputs ($ fp, $ http_entity_body. "\ r \ n ");

While (! Feof ($ fp )){
$ D. = fgets ($ fp, 4096 );
}
Fclose ($ fp );
Echo $ d;
}

We can use ngrep to capture http Request packets (because we need to know php: // input, we only capture http Request packets here ). Run the test script phpinput_post.php.

@ Php/phpinput_post.php
HTTP/1.1 200 OK
Date: Thu, 08 Apr 2010 03:23:36 GMT
Server: Apache/2.2.3 (CentOS)
X-Powered-By: PHP/5.1.6
Content-Length: 160
Connection: close
Content-Type: text/html; charset = UTF-8
------- $ _ POST ------------------
Array (2 ){
["N"] => string (9) "perfgeeks"
["P"] => string (4) "7788"
}
------- Php: // input -------------
N = perfgeeks & p = 7788.
The http Request Packet captured through ngrep is as follows:

T 192.168.0.8: 57846-> 192.168.0.6: 80 [AP]
POST/phpinput_server.php HTTP/1 ..
Host: 192.168.0.6 .. Content-Type: application/x-www-form-urlencoded... Co
Ntent-Length: 18... Connection: close... n = perfgeeks & p = 7788 ....

After careful observation, we can easily find that:

$ _ POST data. php: // the input data is "consistent" with the httpd entity body data.
The Content-Type in the http request is application/x-www-form-urlencoded, which indicates that the data in the http Request body is the form data submitted using the http post method, and urlencode () is processed.
(Note: note that the content in bold is not prompted below ).

Let's take a look at the original file content of the script phpinput_xmlrpc.php, which simulates an xml-rpc Request Submitted by the POST method.

// @ File phpinput_xmlrpc.php
$ Http_entity_body = "\ n jt_userinfo \ n ";
$ Http_entity_type = 'text/html ';
$ Http_entity_length = strlen ($ http_entity_body );
$ Host = '1970. 168.0.6 ';
$ Port = 80;
$ Path = '/phpinput_server.php ';
$ Fp = fsockopen ($ host, $ port, $ error_no, $ error_desc, 30 );
If ($ fp ){
Fputs ($ fp, "POST {$ path} HTTP/1.1 \ r \ n ");
Fputs ($ fp, "Host: {$ host} \ r \ n ");
Fputs ($ fp, "Content-Type: {$ http_entity_type} \ r \ n ");
Fputs ($ fp, "Content-Length: {$ http_entity_length} \ r \ n ");
Fputs ($ fp, "Connection: close \ r \ n ");
Fputs ($ fp, $ http_entity_body. "\ r \ n ");
While (! Feof ($ fp )){
$ D. = fgets ($ fp, 4096 );
}

Fclose ($ fp );
Echo $ d;
}
Similarly, let's execute this test script:

@ Php/phpinput_xmlrcp.php
HTTP/1.1 200 OK
Date: Thu, 08 Apr 2010 03:47:18 GMT
Server: Apache/2.2.3 (CentOS)
X-Powered-By: PHP/5.1.6
Content-Length: 154
Connection: close
Content-Type: text/html; charset = UTF-8

------- $ _ POST ------------------
Array (0 ){
}

------- Php: // input -------------


Jt_userinfo

When executing this script, the http request packet captured through ngrep is as follows:

T 192.168.0.8: 45570-> 192.168.0.6: 80 [AP]
POST/phpinput_server.php HTTP/1 ..
Host: 192.168.0.6 .. Content-Type: text/html... Content-Length: 75 .. Connec
Tion: close .... . . Jt_userinfo <
/Name>. ....
Similarly, I can easily find that:

The Content-Type in the http request is text/xml. It indicates that the body data in the http request is in xml format.
The server $ _ POST prints an empty array, which is inconsistent with the http entity body. This is different from the previous example. The Content-Type here is text/xml, not application/x-www-form-urlencoded.
Php: // the input data is consistent with the http entity body data. That is, php: // the input data is inconsistent with the $ _ POST data.
Let's take a look at the situation where the form data is submitted using the GET method. Can php: // input read the form data of the GET method? Here, we will slightly change the phpinput_server.php file and change $ _ POST to $ _ GET.

// @ File phpinput_server.php
$ Raw_post_data = file_get_contents ('php: // input', 'R ');
Echo "------- \ $ _ GET ------------------ \ n ";
Echo var_dump ($ _ GET). "\ n ";
Echo "------- php: // input ------------- \ n ";
Echo $ raw_post_data. "\ n ";
// @ File phpinput_get.php
$ Query_path = 'n' = '. urldecode ('perfgeeks'). '& p ='. urldecode ('20140901 ');
$ Host = '1970. 168.0.6 ';
$ Port = 80;
$ Path = '/phpinput_server.php ';
$ D = '';
$ Fp = fsockopen ($ host, $ port, $ error_no, $ error_desc, 30 );
If ($ fp ){
Fputs ($ fp, "GET {$ path }? {$ Query_path} HTTP/1.1 \ r \ n ");
Fputs ($ fp, "Host: {$ host} \ r \ n ");
Fputs ($ fp, "Connection: close \ r \ n ");

While (! Feof ($ fp )){
$ D. = fgets ($ fp, 4096 );
}
Fclose ($ fp );
Echo $ d;
}
Similarly, we run the next phpinput_get.php test script, which simulates a common GET method to submit form data.

@ Php/phpinput_get.php
HTTP/1.1 200 OK
Date: Thu, 08 Apr 2010 07:38:15 GMT
Server: Apache/2.2.3 (CentOS)
X-Powered-By: PHP/5.1.6
Content-Length: 141
Connection: close
Content-Type: text/html; charset = UTF-8

------- $ _ GET ------------------
Array (2 ){
["N"] =>
String (9) "perfgeeks"
["P"] =>
String (4) 7788"
}

------- Php: // input -------------
At this time, the ngrep tool is used to capture the corresponding http request packet as follows:

T 192.168.0.8: 36775-> 192.168.0.6: 80 [AP]
GET/phpinput_server.php? N = perfgeeks & p = 7788 HTTP/1 ..
Host: 192.168.0.6 .. Connection: close ....
Compare the http requests submitted by the POST method. Generally, the entity body is empty in the requests submitted by the GET method. Content-Type and Content-Length are not specified. However, if the strong data is http entity body and the Content-Type and Content-Length are specified correctly, php: // input still reads the http entity body data, but not $ _ GET data.

Based on the above probes, We can summarize the following:

When the Content-Type value is application/x-www-form-urlencoded, php will fill in the corresponding data of the http Request body in the array $ _ POST, the data filled in the $ _ POST array is the result of urldecode () parsing. (In fact, in addition to the Content-Type, there is also multipart/form-data indicating that the data is form data. We will introduce it later)
Php: // input data, as long as the Content-Type is not multipart/form-data (this restriction will be introduced later ). Php: // the input data is consistent with the part of the http entity body. The consistent data Length is specified by Content-Length.
Only when Content-Type is application/x-www-form-urlencoded and the submission method is POST method, $ _ POST data and php: // The input data is "consistent" (with quotation marks, indicating that the formats are inconsistent and the content is consistent. In other cases, they are inconsistent.
Php: // input cannot read $ _ GET data. The reason is that the $ _ GET data is written in the PATH field of the http Request header as query_path, rather than in the http Request body.
This also helps us understand why the xml_rpc server reads data through file_get_contents ('php: // input', 'R '). Instead of reading from $ _ POST, it is because the xml_rpc data Type is xml, and its Content-Type is text/xml.

Php: // input has encountered multipart/form-data

When uploading files, the form is written as follows:

Enctype = multipart/form-data indicates that the Content-Type in the http Request Header (head) is set to multipart/form-data. Refer to RFC1867's description. Multipart/form-data also means to submit form data using the POST method. It is also accompanied by file upload, so it will be different from the data format of application/x-www-form-urlencoded. It is passed to the server in a more reasonable and efficient data format. We submit the form data and print the response results as follows:


------- $ _ POST ------------------
Array (1) {["n"] => string (9) "perfgeeks "}
------- Php: // input -------------
At the same time, the corresponding http Request Packet captured through ngrep is as follows:

########
T 192.168.0.8: 3981-> 192.168.0.6: 80 [AP]
POST/phpinput_server.php HTTP/1. 1 .. Host: 192.168.0.6 .. Connection: kee
P-alive .. User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US)
PpleWebKit/533.2 (KHTML, like Gecko) Chrome/5.0.342.3 Safari/533. 2 .. Re
Ferer: http: // 192.168.0.6/phpinput_server.php... Content-Length: 306... Ca
Che-Control: max-age = 0 .. Origin: http://192.168.0.6..Content-Type: mult
Ipart/form-data; boundary = ---- WebKitFormBoundarybLQwkp4opIEZn1fA .. Acce
Pt: application/xml, application/xhtml + xml, text/html, q = 0.9, text/plain; q
= 0.8, image/png, */*; q = 0. 5 .. Accept-Encoding: gzip, deflate, sdch... Accept-L
Anguage: zh-CN, zh; q = 0. 8 .. Accept-Charset: GBK, UTF-8; q = 0.7, *; q = 0. 3 .. Cook
Ie: SESS3b0e658f87cf58240de13ab43a399df6 = lju6o5bg8u04lv1ojugm2ccic6...
.
##
T 192.168.0.8: 3981-> 192.168.0.6: 80 [AP]
------ WebKitFormBoundarybLQwkp4opIEZn1fA... Content-Disposition: form-da
Ta; name = "n"... perfgeeks... ------ WebKitFormBoundarybLQwkp4opIEZn1fA.. C
Ontent-Disposition: form-data; name = "f"; filename = "test.txt"... Content-
Type: text/plain... I am file... multipart/form-data... ------ WebKitFormBo
UndarybLQwkp4opIEZn1fA --..
##
Compare from the response output. The $ _ POST data is consistent with the data submitted by the request, that is, $ _ POST = array ('n' => 'perfgeek '). This also echoes the data in the http Request body. It also indicates that PHP fills in the corresponding data with the $ _ POST global variable. Php: // the input output is empty and nothing is output, although the body of the http request packet is not empty. This indicates that when the Content-Type is multipart/form-data, php: // input is empty even if there is data in the http Request body. In this case, php: // input stream is not entered. Therefore, php: // input cannot be used to read data from enctype = multipart/form-data.

After comparing the http request data packets captured through ngrep, we will find that the biggest difference is that Content-Type follows boundary and defines the data delimiter, bounday is randomly generated. Another big difference is that the data organization structure in the http entity body is different.

In the previous section, we have outlined that when Content-Type is application/x-www-form-urlencoded, php: // input and $ _ POST data are "consistent, when it is other Content-Type, php: // input and $ _ POST data are inconsistent. Because only when the Content-Type is application/x-www-form-urlencoded or multipart/form-data, PHP will fill in the corresponding part of the body of the http request packet in the $ _ POST global variable. PHP will ignore this in other cases. Php: // input is not empty unless the data type is multipart/form-data. Through this section, we understand the difference and connection between php: // input and $ _ POST. So, confirm again that php: // input cannot read enctype = multipart/form-data. When php: // input encounters it, it is always blank, even if the http entity body has data.

Php: // input VS $ http_raw_post_data

I believe you have a deep understanding of php: // input. So what is $ http_raw_post_data? $ Http_raw_post_data is a built-in global variable in PHP. It is used. PHP fills in the POST data as is in the variable $ http_raw_post_data when the Content-Type cannot be recognized. It cannot read POST data whose Content-Type is multipart/form-data. You need to set the always_populate_raw_post_data value in php. ini to On, and PHP will always fill in the POST data with the variable $ http_raw_post_data.

Change the script phpinput_server.php to verify the above content:

$ Raw_post_data = file_get_contents ('php: // input', 'R ');
$ Rtn = ($ raw_post_data = $ HTTP_RAW_POST_DATA )? 1: 0;
Echo $ rtn;

Run the test script:

@ Php phpinput_post.php
@ Php phpinput_get.php
@ Php phpinput_xmlrpc.php

The output result is the same, that is, all values are 1, indicating that php: // input and $ HTTP_RAW_POST_DATA are the same. As for the memory pressure, we will not perform a detailed test here. If you are interested, you can use xhprof for testing and observation.

In this section, we can summarize the following:

Php: // input can read the value of the specified Length in the http entity body, which is determined by Content-Length, whether it is the data submitted by the POST or GET method. However, when the GET method submits data, the http request entity body is empty.
Php: // input and $ HTTP_RAW_POST_DATA read the same data, and only read data whose Content-Type is not multipart/form-data.
Summary

Coentent-Type can only be set to application/x-www-data-urlencoded or multipart/form-data, PHP will fill in the corresponding data in the http request packet with the global variable $ _ POST

When PHP cannot recognize the Content-Type, it will fill in the corresponding data in the http request package with the variable $ HTTP_RAW_POST_DATA
Only when the Coentent-Type is not multipart/form-data, PHP will not fill in the corresponding data in the http request packet in php: // input; otherwise, it will be used in other cases. Length Specified by Coentent-Length.

Php: // input data is consistent with $ _ POST data only when Content-Type is application/x-www-data-urlencoded.
Php: // the input data is always the same as $ HTTP_RAW_POST_DATA, but php: // the input data is more efficient than $ HTTP_RAW_POST_DATA, and php. ini does not require special settings.

PHP will fill in the query_path section of the PATH field with the global variable $ _ GET. Normally, the http Request Submitted by The GET method has no body.

Large-Scale Price Reduction
  • 59% Max. and 23% Avg.
  • Price Reduction for Core Products
  • Price Reduction in Multiple Regions
undefined. /
Connect with us on Discord
  • Secure, anonymous group chat without disturbance
  • Stay updated on campaigns, new products, and more
  • Support for all your questions
undefined. /
Free Tier
  • Start free from ECS to Big Data
  • Get Started in 3 Simple Steps
  • Try ECS t5 1C1G
undefined. /

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.