fopen php output,php://input和php://output

php://input 是个可以访问请求的原始数据的只读流。 POST 请求的情况下,最好使用 php://input 来代替 $HTTP_RAW_POST_DATA(原生的post数据),因为它不依赖于特定的 php.ini 指令,内存消耗更少。

官方解释:

$http_raw_post_data 是什么?

$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");

get&post提交表单

GET提交

请求头中不会指定Content-Type和Content-Length,它表示http请求body中的数据是使用http的post方法提交的表单数据,并且进行了urlencode()处理。

POST提交

Content-Type为application/x-www-form-urlencoded或者为multipart/form-data的时候,PHP才会将http请求数据包中的body相应部分数据填入$_POST全局变量中(时用$_POST可以接收数据),其它情况PHP都忽略。

php://input无法读取 enctype=multipart/form-data数据,当php://input遇到它时,永远为空,即便http entity body有数据。

为什么叫部分填入呢? 为multipart/form-data的时候,表单的数据不会填入到到 $_POST中,而是填入到了 $_FILES中。

php://input 与 $HTTP_RAW_POST_DATA 比较:

php://input 与$HTTP_RAW_POST_DATA读取的数据是一样的,都只读取Content-Type不为multipart/form-data的数据。

总结:

Coentent-Type仅在取值为application/x-www-data-urlencoded和multipart/form-data两种情况下,PHP才会将http请求数据包中相应的数据填入全局变量$_POST。

当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指定。

GET请求将,PHP会将PATH字段的query_path部分,填入全局变量$_GET。通常情况下,GET方法提交的http请求,body为空。

简介

用法:

test.php文件:

$output = fopen("php://output", "w");

fwrite($output, "爱E族");

fclose($output);

输出:

[root@aiezu.com ~]# php test.php

爱E族

注意,以UTF8编码导出CSV文件,如果文件头未添加BOM头,使用Excel打开会出现乱码。

test.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里的运用)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值