(PHP 4, PHP 5, PHP 7, PHP 8)
readfile — 输出文件
$filename
, bool $use_include_path
= false
, resource $context
= ?
) : int读取文件并写入到输出缓冲。
filename
要读取的文件名。
use_include_path
想要在
include_path
中搜索文件,可使用这个可选的第二个参数,设为 true
。
context
Stream 上下文(context) resource。
成功时返回从文件中读入的字节数, 或者在失败时返回 false
失败时抛出E_WARNING
警告。
示例 #1 使用 readfile() 强制下载
<?php
$file = 'monkey.gif';
if (file_exists($file)) {
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="'.basename($file).'"');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
readfile($file);
exit;
}
?>
以上例程的输出类似于:
注意:
readfile() 自身不会导致任何内存问题。 如果出现内存不足的错误,使用 ob_get_level() 确保输出缓存已经关闭。
如已启用fopen 包装器,在此函数中, URL 可作为文件名。关于如何指定文件名详见 fopen()。各种 wapper 的不同功能请参见 支持的协议和封装协议,注意其用法及其可提供的预定义变量。
注意: 在 PHP 5.0.0 中增加了对上下文(Context)的支持。有关
上下文(Context)
的说明参见 Streams。