您的位置:首页 >php的特殊协议php://
发布于2026-05-03 阅读(0)
扫一扫,手机访问
在PHP的世界里,除了常规的文件和网络操作,还内置了一套非常实用的“特殊通道”——php://协议。它本质上是一组杂项输入/输出(I/O)流包装器,为我们打开了访问PHP进程自身I/O系统的一扇门。通过它,你可以直接操作标准输入/输出、错误描述符,使用内存或磁盘支持的临时数据流,甚至能在数据流被读取前就应用各种过滤器。这为许多高级或底层的操作提供了极大的便利。
这三个流分别对应着PHP进程的标准输入、标准输出和标准错误流。它们允许你的脚本直接与启动它的环境(比如命令行)进行通信。
需要留意的是,php://stdin、php://stdout 和 php://stderr 引用的其实是相应文件描述符的副本。这意味着,即使你打开了php://stdin然后关闭它,也只是关闭了这个副本,真正的STDIN常量所代表的流并不会受到影响。不过,在PHP 5.2.1之前,这方面的行为存在一些已知的BUG。因此,一个更简单直接的建议是:与其手动打开这些封装器,不如直接使用PHP提供的常量STDIN、STDOUT和STDERR,它们用起来更省心。
在访问权限上,php://stdin是只读的,而php://stdout和php://stderr则是只写的。
这是一个非常常用且强大的只读流,用于访问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等其他请求方式则不一定适用。
这是一个只写流,允许你像使用print或echo一样,将数据直接写入到输出缓冲区。它在需要自定义输出处理逻辑时非常有用。
这个协议允许直接访问指定的文件描述符。语法很简单,例如php://fd/3就表示引用文件描述符3。这为操作已打开的文件句柄提供了另一种途径。
这两个流扮演着“临时数据容器”的角色,行为类似文件包装器,允许进行读写操作。它们的核心区别在于数据存储的策略:
sys_get_temp_dir()函数决定。对于php://temp,你还可以通过/maxmemory:NN参数来自定义这个内存阈值,其中NN是你希望数据保留在内存中的最大字节数。
这是一个设计精巧的“元封装器”。它的核心价值在于,可以在数据流被打开的同时就应用一个或多个过滤器进行处理。这对于readfile()、file()和file_get_contents()这类“一体式”文件函数尤其有用,因为这些函数在读取数据前,通常没有给我们留下插入处理逻辑的机会。
使用php://filter时,需要将过滤参数作为路径的一部分。你甚至可以组合多个过滤器,形成一条处理链。它的路径支持以下参数:
| 名称 | 描述 |
|---|---|
resource=<要过滤的数据流> | 这是必须的参数。它指定了你要进行筛选过滤的原始数据流来源。 |
read=<读链的筛选列表> | 该参数可选。用于设定一个或多个应用于读取链的过滤器名称,多个过滤器之间用管道符(|)分隔。 |
write=<写链的筛选列表> | 该参数可选。用于设定一个或多个应用于写入链的过滤器名称,同样以管道符(|)分隔。 |
<两个链的筛选列表> | 任何没有以read=或write=作为前缀的过滤器列表,将会根据情况自动应用于读链或写链。 |
下表总结了php://下各协议支持的功能特性(对于php://filter,其支持情况取决于被过滤的底层封装器):
| 属性 | 支持情况 |
|---|---|
| 受限于 allow_url_fopen | 否 |
| 受限于 allow_url_include | 仅 php://input、php://stdin、php://memory 和 php://temp。 |
| 允许读取 | 仅 php://stdin、php://input、php://fd、php://memory 和 php://temp。 |
| 允许写入 | 仅 php://stdout、php://stderr、php://output、php://fd、php://memory 和 php://temp。 |
| 允许追加 | 仅 php://stdout、php://stderr、php://output、php://fd、php://memory 和 php://temp(等同于写入)。 |
| 允许同时读写 | 仅 php://fd、php://memory 和 php://temp。 |
| 支持 stat() | 仅 php://memory 和 php://temp。 |
| 支持 unlink() | 否 |
| 支持 rename() | 否 |
| 支持 mkdir() | 否 |
| 支持 rmdir() | 否 |
| 支持 stream_select() | php://stdin、php://stdout、php://stderr、php://fd 和 php://temp。 |
| 版本 | 说明 |
|---|---|
| 5.3.6 | 增加了 php://fd。 |
| 5.1.0 | 增加了 php://memory 和 php://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
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9