(PHP 4, PHP 5, PHP 7, PHP 8)
readfile — Gibt eine Datei aus
Liest den Inhalt einer Datei und schreibt ihn in den Ausgabepuffer.
filenameDer Name der Datei, die gelesen werden soll.
use_include_path
Sie können optional den zweiten Parameter benutzen und diesen auf
true setzen, wenn Sie auch im
include_path nach der Datei
suchen möchten.
contextEine Stream-Kontext-Ressource.
Gibt bei Erfolg die Anzahl der gelesenen Bytes einer Datei zurück.
Bei einem Fehler wird false zurückgegeben.
Im Fehlerfall wird eine E_WARNING ausgegeben.
Beispiel #1 Einen Download unter Verwendung von readfile() erzwingen
<?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;
}
?>Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
Hinweis:
readfile() weist für sich allein keine Speicherprobleme auf, selbst wenn große Dateien gesendet werden. Wenn Sie auf einen out-of-memory-Fehler treffen, stellen Sie mit ob_get_level() sicher, dass die Ausgabepufferung deaktiviert ist.
Wenn fopen wrappers aktiviert ist, kann mit dieser Funktion eine URL als Dateiname verwendet werden. Mehr Details dazu, wie der Dateiname angeben werden muss, sind bei fopen() zu finden. Eine Liste der unterstützten URL-Protokolle, die Fähigkeiten der verschiedenen Wrapper, Hinweise zu deren Verwendung und Informationen zu den eventuell vorhandenen vordefinierten Variablen sind unter Unterstützte Protokolle und Wrapper zu finden.