PHP-"php://(类型)"访问各个输入/输出流以及全局变量$HTTP_RAW_POST_DATA讲解
$_POST
$HTTP_RAW_POST_DATA
php://input
先来讲以上三者的区别:
$_POST:以关联数组方式组织提交的数据, 并对原数据进行编码处理(urldecode)和编码转换, 无论表单enctype为何值, $_POST都可以成功取到传值, 但是碰到不能识别解析的(比如POST过来的Content-Type为text/xml)就无法解析为$_POST数组, 转而交给$HTTP_RAW_POST_DATA(如何POST xml可以使用curl, fsockopen等设置POST的Content-Type, 接收xml文件可以用以下两种$HTTP_RAW_POST_DATA, 或者file_get_contents('php://input'))
$HTTP_RAW_POST_DATA:仅在PHP被POST过来不能识别的MIME类型(Content-Type)(比如text/xml或者soap 等等)的时候, 会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DATA, 并且对于enctype="multipart/form-data"表单数据不可用
php://input:可通过输入流以文件读取方式取得未经处理的POST原始数据, 并且对于enctype="multipart/form-data"表单数据不可用(除了表单类型单一外, 可以获取任何POST过来的数据), 读取不到$_GET数据, 是因为$_GET数据作为query_path写在http请求头部(header)的PATH字段, 而不是写在http请求的body部分
总结:
1.Content-Type仅在取值为application/x-www-data-urlencoded和multipart/form-data两种情况下, PHP才会将http请求数据包中相应的数据填入全局变量$_POST
2.PHP不能识别的Content-Type类型的时候, 会将http请求包中相应的数据填入变量$HTTP_RAW_POST_DAT
3.只有Coentent-Type不为multipart/form-data的时候, PHP不会将http请求数据包中的相应数据填入php://input, 否则其它情况都会
4.只有Content-Type为application/x-www-data-urlencoded时, php://input数据才跟$_POST数据相一致
5.php://input比$HTTP_RAW_POST_DATA更凑效, 且不需要特殊设置php.ini
6.PHP会将PATH字段的query_path部分填入全局变量$_GET, 通常情况下, GET方法提交的http请求, body为空
以上结论摘抄自:http://www.jb51.net/article/31317.htm
讲到php://input再来讲PHP的各种输入/输出流
PHP提供了一些杂项输入/输出(IO)流, 允许访问PHP的输入输出流、标准输入输出和错误描述符, 内存中、磁盘备份的临时文件流以及可以操作其他读取写入文件资源的过滤器
php://stdin, php://stdout和php://stderr
以上三个允许直接访问PHP进程相应的输入或者输出流(进程模式的PHP), 数据流引用了复制的文件描述符, 所以如果你打开php://stdin并在之后关了它, 仅是关闭了复制品, 真正被引用的STDIN并不受影响
php://stdin是只读的, php://stdout和php://stderr是只写的
php://input
可以访问请求的原始数据的只读流(获取请求头的body部分), 打开的数据流只能读取一次, 数据流不支持seek操作
php://output
是一个只写的数据流, 允许你以print和echo一样的方式写入到输出缓冲区
php://fd
允许直接访问指定的文件描述符
php://memory和php://temp
php://memory和php://temp是一个类似文件包装器的数据流, 允许读写临时数据, 两者的唯一区别是php://memory总是把数据储存在内存中, 而php://temp会在内存量达到预定义的限制后(默认是2MB)存入临时文件中, 临时文件位置的决定和sys_get_temp_dir()的方式一致, php://temp的内存限制可通过添加/maxmemory:NN来控制, NN 是以字节为单位、保留在内存的最大数据量, 超过则使用临时文件
PHP-"php://(类型)"访问各个输入/输出流以及全局变量$HTTP_RAW_POST_DATA讲解的更多相关文章
- php:// — 访问各个输入/输出流(I/O streams)
PHP: php:// - Manual http://www.php.net/manual/zh/wrappers.php.php php:// php:// — 访问各个输入/输出流(I/O st ...
- php:// 访问各个输入/输出流
相关 php.ini 配置 allow_url_fopen :on 默认开启 该选项为on便是激活了 URL 形式的 fopen 封装协议使得可以访问 URL 对象文件等. allow_url_inc ...
- 序列流、对象操作流、打印流、标准输入输出流、随机访问流、数据输入输出流、Properties(二十二)
1.序列流 * 1.什么是序列流 * 序列流可以把多个字节输入流整合成一个, 从序列流中读取数据时, 将从被整合的第一个流开始读, 读完一个之后继续读第二个, 以此类推.* 2.使用方式 * 整合两个 ...
- 第27章 java I/O输入输出流
java I/O输入输出流 1.编码问题 import java.io.UnsupportedEncodingException; /** * java涉及的编码 */ public class En ...
- 【转】输入/输出流 - 全面掌握IO
File类: 程序中操作文件和目录都可以使用File类来完成即不管是文件还是目录都是使用File类来操作的,File能新建,删除,重命名文件和目录,但File不能访问文件内容本身,如果需要访问文件本身 ...
- Java 输入输出流 转载
转载自:http://blog.csdn.net/hguisu/article/details/7418161 1.什么是IO Java中I/O操作主要是指使用Java进行输入,输出操作. Java所 ...
- Java I/O输入输出流详解
一.文件的编码 开发时一定要注意项目默认的编码!!!!!!!! 文件操作的时候一定要记得关闭!!!!!!!! ASCII:美国标准 ...
- Java-IO 输入输出流详解
一.文件的编码 开发时一定要注意项目默认的编码!!!!!!!! 文件操作的时候一定要记得关闭!!!!!!!! ASCII:美国标准 ...
- java输入输出流总结 转载
一.基本概念 1.1 什么是IO? IO(Input/Output)是计算机输入/输出的接口.Java中I/O操作主要是指使用Java进行输入,输出操作. Java所有的I/O机制都是 ...
随机推荐
- Hive集合数据类型
Hive的列除了支持基本的数据类型外,还支持使用Struct.Map和Array三种集合数据类型. 假设某表有如下一行,我们用JSON格式来表示其数据结构.在Hive下访问的格式为 { "n ...
- linux基础命令学习 (九)文本操作
一.head 1.语法: head [选项] [文件] 2.选项 -q 隐藏文件名 -v 显示文件名 -c<字节> 显示字节数 -n<行数> 显示的行数 3.示例 范例一:查看 ...
- linux下如何启动sybase
isql -Dxxx -Uxxx -P111111 用isql连接数据库发现数据库没有启动. 如何启动sybase数据库? [TA_SYBASE][/home/bta]su - sybase //切 ...
- Nagios 监控mysqlserver具体实现过程
,之后在页面就能够看到监控效果了 參考文章:http://os.51cto.com/art/201409/452605.htm
- Highcharts构建分组分类坐标轴
Highcharts构建分组分类坐标轴 分组分类坐标轴是将坐标轴的类别标签进行进一步分组,从而形成双层.多层结构. 这样更利于数据分组展现. 实现分组分类坐标轴须要借助第三方插件Grouped-Cat ...
- localhost与127.0.0.1的区别 2
localhost与127.0.0.1的区别localhost与127.0.0.1的区别是什么?相信有人会说是本地ip,曾有人说,用127.0.0.1比localhost好,可以减少一次解析.看来这个 ...
- java内存泄露补充样例
前几天写了个内存泄露的文章.里面介绍了内存泄露的相关知识:http://blog.csdn.net/u010590685/article/details/46973735 但是里面给的样例不是非常好, ...
- C语言跟内存分配方式-alloc malloc calloc
转载:http://blog.csdn.net/ubuntulover/article/details/7581317 (1) 从静态存储区域分配.内存在程序编译的时候就已经分配好,这块内存在程序的整 ...
- KVM-Introduce
相信非常多的人对虚拟机并不陌生,眼下也有非常多优秀的虚拟机软件,比如:VMware, VirtualBox, Xen, KVM等.而本文的主要内容是介绍KVM. KVM: Kernel Based V ...
- python 实现Hadoop的partitioner和二次排序
我们知道,一个典型的Map-Reduce过程包 括:Input->Map->Partition->Reduce->Output. Partition负责把Map任务输出的中间结 ...