Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann ich die Dateigröße einer hochgeladenen Datei in Echtzeit lesen und wiedergeben?

Wie kann ich die Dateigröße einer hochgeladenen Datei in Echtzeit lesen und wiedergeben?

Mary-Kate Olsen
Freigeben: 2024-10-20 22:07:02
Original
775 Leute haben es durchsucht

How to Read and Echo File Size of Uploaded File in Real Time?

Lesen und Echo der Dateigröße der hochgeladenen Datei, die in Echtzeit geschrieben wird

Das Hochladen von Dateien ist zwar eine häufige Aufgabe, kann jedoch eine Herausforderung sein Fortschrittsinformationen anzeigen, ohne sowohl den Server als auch den Client zu blockieren. In diesem Artikel wird erläutert, wie dies mithilfe einer Kombination aus serverseitigen und clientseitigen Technologien erreicht werden kann.

Hintergrund

Stellen Sie sich eine Anwendung vor, bei der Dateien mithilfe von auf einen Server hochgeladen werden fetch(), wobei der Körper auf ein Blob-, File-, TypedArray- oder ArrayBuffer-Objekt festgelegt ist. Ziel ist es, die Dateigröße der hochgeladenen Datei in Echtzeit zu lesen und wiederzugeben, sodass der Client den Fortschritt anzeigen kann, während die Datei auf dem Server geschrieben wird.

Serverseitige Implementierung (z. B. , PHP)

Die serverseitige Implementierung umfasst zwei Skripte: „data.php“ zum Schreiben der Datei auf den Server und „stream.php“ zum Streamen der Dateigröße an den Client.

data.php:

<code class="php">$filename = $_SERVER["HTTP_X_FILENAME"];
$input = fopen("php://input", "rb");
$file = fopen($filename, "wb");
stream_copy_to_stream($input, $file);
fclose($input);
fclose($file);
echo "upload of " . $filename . " successful";</code>
Nach dem Login kopieren

stream.php:

<code class="php">header("Content-Type: text/event-stream");
header("Cache-Control: no-cache");
header("Connection: keep-alive");

while(true) {
    $upload = $_GET["filename"];
    $data = filesize($upload);
    if ($data) {
        sendMessage($lastId, $data);
        $lastId++;
    }
}

function sendMessage($id, $data) {
    echo "id: $id\n";
    echo "data: $data\n\n";
    ob_flush();
    flush();
}</code>
Nach dem Login kopieren

Clientseitige Implementierung ( (z. B. JavaScript)

Die clientseitige Implementierung verwendet fetch() zum Hochladen der Datei und eine EventSource, um die Aktualisierungen der Dateigröße vom Server zu empfangen.

<code class="javascript">const input = document.querySelector("input[type=file]");
const progress = document.querySelector("progress");
input.addEventListener("change", (event) => {
    const file = input.files[0];
    const request = new Request('data.php', {
        method: "POST",
        headers: { 'x-filename': file.name },
        body: file
    });
    const source = new EventSource('stream.php?filename=' + file.name);
    source.addEventListener("message", (e) => {
        progress.value = e.data;
    }, true);
});</code>
Nach dem Login kopieren

Zusätzliche Überlegungen

Um potenzielle Probleme beim Schreiben oder Lesen von Dateien zu behandeln, können Fehlerbehandlungsmechanismen integriert werden. Darüber hinaus ist es wichtig, den Dateigrößen-Cache zu leeren, um genaue Aktualisierungen der Dateigröße zu gewährleisten.

Fazit

Durch Befolgen dieser Schritte können Sie die Dateigröße in Echtzeit ablesen und Echo hochgeladener Dateien, ohne den Server oder Client zu blockieren. Dies ermöglicht eine nahtlose Fortschrittsverfolgung für Datei-Uploads sowohl auf der Client- als auch auf der Serverseite.

Das obige ist der detaillierte Inhalt vonWie kann ich die Dateigröße einer hochgeladenen Datei in Echtzeit lesen und wiedergeben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage