php://input 是个能够访问请求的原始数据的只读流。 POST 请求的状况下,最好使用 php://input 来代替 $HTTP_RAW_POST_DATA(原生的post数据),由于它不依赖于特定的 php.ini 指令,内存消耗更少。php
$http_raw_post_data是PHP内置的一个全局变量。它用于,PHP在没法识别的Content-Type的状况下,将POST过来的数据原样地填入变量$http_raw_post_data。它一样没法读取Content-Type为multipart/form-data的POST数据。须要设置php.ini中的always_populate_raw_post_data值为On,PHP才会总把POST数据填入变量$http_raw_post_data。浏览器
PHP在没法识别的Content-Type的状况下,才将POST过来的数据原样地填入变量$http_raw_post_data。网络
$data = file_get_contents("php://input");
请求头中不会指定Content-Type和Content-Length,它表示http请求body中的数据是使用http的post方法提交的表单数据,而且进行了urlencode()处理。app
Content-Type为application/x-www-form-urlencoded或者为multipart/form-data的时候,PHP才会将http请求数据包中的body相应部分数据填入$_POST全局变量中(时用$_POST能够接收数据),其它状况PHP都忽略。post
php://input除了在数据类型为multipart/form-data以外为空外,其它状况均可能不为空。编码
php://input没法读取 enctype=multipart/form-data数据,当php://input遇到它时,永远为空,即使http entity body有数据。url
为何叫部分填入呢? 为multipart/form-data的时候,表单的数据不会填入到到 $_POST中,而是填入到了 $_FILES中。命令行
php://input 与$HTTP_RAW_POST_DATA读取的数据是同样的,都只读取Content-Type不为multipart/form-data的数据。
读取的数据是同样的,可是填入数据的条件不同,post提交时,php://input就会填入,而$HTTP_RAW_POST_DATA只有再不能识别Content-Type时填入。code
当Coentent-Type为application/x-www-data-urlencoded时 填入到$_POST数组中的数据是进行urldecode()解析的结果
只有Content-Type为application/x-www-data-urlencoded时,php://input数据才跟$_POST数据相"一致"(打上引号,表示它们格式不一致,内容一致)
PHP不能识别的Content-Type类型的时候,会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DATA
只有Coentent-Type不为multipart/form-data的时候,PHP不会将http请求数据包中的相应数据填入php://input,不然其它状况都会。填入的长度,由Coentent-Length指定。
php://input数据老是跟$HTTP_RAW_POST_DATA相同,可是php://input比$HTTP_RAW_POST_DATA更凑效,且不须要特殊设置php.ini
php://input读取不到$_GET数据。是由于$_GET数据做为query_path写在http请求头部(header)的PATH字段,而不是写在http请求的body部分。
GET请求将,PHP会将PATH字段的query_path部分,填入全局变量$_GET。一般状况下,GET方法提交的http请求,body为空。
php://output是php语言中一个只写的数据流,容许像 print() 和 echo() 同样的方式写入到输出缓冲区;“php://output”支持CLI(command-line interface,命令行界面)模式和Http模式;
test.php文件:
<?php $output = fopen("php://output", "w"); fwrite($output, "爱E族"); fclose($output);
输出:
[root@aiezu.com ~]# php test.php 爱E族
注意,以UTF8编码导出CSV文件,若是文件头未添加BOM头,使用Excel打开会出现乱码。
test.php页面代码:
<?php header('Content-Type: application/csv'); header('Content-Disposition: attachment; filename="test.csv"'); $output = fopen('php://output','w') or die("Can't open php://output"); //UTF8 csv文件头前需添加BOM,否则会是乱码 fwrite($output, chr(0xEF).chr(0xBB).chr(0xBF)); // 输出标题行 fputcsv($output, array('站点名', '域名', '行业')); //数据内容 $rows = array( array('天猫', 'http://tmall.com', '电子商务') ,array('爱E族', 'http://aiezu.com', '互联网技术') ,array('腾讯', 'http://qq.com', '社交网络') ); foreach($rows as $row) { fputcsv($output, $row); } fclose($output) or die("Can't close php://output");
常见的应用:读取数据输出到浏览器(PHPExcel里的运用)