Reads a file and writes it to the output buffer.
The filename being read.
You can use the optional second parameter and set it to TRUE
, if you want to search for the file in the include_path, too.
A context stream resource.
Returns the number of bytes read from the file. If an error occurs, FALSE
is returned and unless the function was called as @readfile(), an error message is printed.
readfile() will not present any memory issues, even when sending large files, on its own. If you encounter an out of memory error ensure that output buffering is off with ob_get_level().
<?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; } ?>
The above example will output something similar to:
file() -
fopen() -
include -
require -
Please login to continue.