商城首页欢迎来到中国正版软件门户

您的位置:首页 >php的特殊协议php://

php的特殊协议php://

  发布于2026-05-03 阅读(0)

扫一扫,手机访问

php://

在PHP的世界里,除了常规的文件和网络操作,还内置了一套非常实用的“特殊通道”——php://协议。它本质上是一组杂项输入/输出(I/O)流包装器,为我们打开了访问PHP进程自身I/O系统的一扇门。通过它,你可以直接操作标准输入/输出、错误描述符,使用内存或磁盘支持的临时数据流,甚至能在数据流被读取前就应用各种过滤器。这为许多高级或底层的操作提供了极大的便利。

php://stdin, php://stdout 和 php://stderr

这三个流分别对应着PHP进程的标准输入、标准输出和标准错误流。它们允许你的脚本直接与启动它的环境(比如命令行)进行通信。

需要留意的是,php://stdinphp://stdoutphp://stderr 引用的其实是相应文件描述符的副本。这意味着,即使你打开了php://stdin然后关闭它,也只是关闭了这个副本,真正的STDIN常量所代表的流并不会受到影响。不过,在PHP 5.2.1之前,这方面的行为存在一些已知的BUG。因此,一个更简单直接的建议是:与其手动打开这些封装器,不如直接使用PHP提供的常量STDINSTDOUTSTDERR,它们用起来更省心。

在访问权限上,php://stdin是只读的,而php://stdoutphp://stderr则是只写的。

php://input

这是一个非常常用且强大的只读流,用于访问HTTP请求的原始数据体。在处理POST请求时,它通常是比$HTTP_RAW_POST_DATA更好的选择,原因有二:首先,它不依赖于php.ini中特定的配置指令(如always_populate_raw_post_data);其次,使用它可以避免填充$HTTP_RAW_POST_DATA可能带来的额外内存开销。

但是,有一个重要的例外:当表单的enctype设置为"multipart/form-data"(通常用于文件上传)时,php://input是无效的,无法使用。

注意: php://input流有一个特点:它只能被读取一次,并且不支持寻址(seek)操作。不过,根据SAPI(服务器API)的具体实现,如果请求体数据被保存了下来,有可能再次打开另一个php://input流进行重读。这种行为通常只针对POST请求,对于PUT或PROPFIND等其他请求方式则不一定适用。

php://output

这是一个只写流,允许你像使用printecho一样,将数据直接写入到输出缓冲区。它在需要自定义输出处理逻辑时非常有用。

php://fd

这个协议允许直接访问指定的文件描述符。语法很简单,例如php://fd/3就表示引用文件描述符3。这为操作已打开的文件句柄提供了另一种途径。

php://memory 和 php://temp

这两个流扮演着“临时数据容器”的角色,行为类似文件包装器,允许进行读写操作。它们的核心区别在于数据存储的策略:

  • php://memory:始终将数据保存在内存中,速度快,但受限于可用内存。
  • php://temp:则更灵活。它会先将数据存储在内存中,但当数据量达到预设的上限(默认是2MB)后,会自动将溢出的数据转存到系统临时目录下的一个真实文件中。这个临时文件的位置由sys_get_temp_dir()函数决定。

对于php://temp,你还可以通过/maxmemory:NN参数来自定义这个内存阈值,其中NN是你希望数据保留在内存中的最大字节数。

php://filter

这是一个设计精巧的“元封装器”。它的核心价值在于,可以在数据流被打开的同时就应用一个或多个过滤器进行处理。这对于readfile()file()file_get_contents()这类“一体式”文件函数尤其有用,因为这些函数在读取数据前,通常没有给我们留下插入处理逻辑的机会。

使用php://filter时,需要将过滤参数作为路径的一部分。你甚至可以组合多个过滤器,形成一条处理链。它的路径支持以下参数:

php://filter 参数
名称描述
resource=<要过滤的数据流>这是必须的参数。它指定了你要进行筛选过滤的原始数据流来源。
read=<读链的筛选列表>该参数可选。用于设定一个或多个应用于读取链的过滤器名称,多个过滤器之间用管道符(|)分隔。
write=<写链的筛选列表>该参数可选。用于设定一个或多个应用于写入链的过滤器名称,同样以管道符(|)分隔。
<两个链的筛选列表>任何没有以read=write=作为前缀的过滤器列表,将会根据情况自动应用于读链或写链。

封装协议摘要

下表总结了php://下各协议支持的功能特性(对于php://filter,其支持情况取决于被过滤的底层封装器):

封装协议摘要
属性支持情况
受限于 allow_url_fopen
受限于 allow_url_includephp://inputphp://stdinphp://memoryphp://temp
允许读取php://stdinphp://inputphp://fdphp://memoryphp://temp
允许写入php://stdoutphp://stderrphp://outputphp://fdphp://memoryphp://temp
允许追加php://stdoutphp://stderrphp://outputphp://fdphp://memoryphp://temp(等同于写入)。
允许同时读写php://fdphp://memoryphp://temp
支持 stat()php://memoryphp://temp
支持 unlink()
支持 rename()
支持 mkdir()
支持 rmdir()
支持 stream_select()php://stdinphp://stdoutphp://stderrphp://fdphp://temp

更新日志

版本说明
5.3.6增加了 php://fd
5.1.0增加了 php://memoryphp://temp
5.0.0增加了 php://filter

范例

Example #1 php://temp/maxmemory

这个例子展示了如何使用可选参数为php://temp设置内存上限。

Example #2 php://filter/resource=<待过滤的数据流>

这个参数必须放在php://filter路径的末尾,用来指定要过滤的源数据流。下面的例子虽然没有实际应用过滤器,但展示了其基本结构。

Example #3 php://filter/read=<读链需要应用的过滤器列表>

这个参数用于指定对读取链应用的一个或多个过滤器。

Example #4 php://filter/write=<写链需要应用的过滤器列表>

这个参数用于指定对写入链应用的一个或多个过滤器。

来自:http://www.php.net/manual/zh/wrappers.php.php

本文转载于:https://blog.csdn.net/tenfyguo/article/details/29569573 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注