Read and Echo File Size of Uploaded File Being Written in Real Time
While file upload is a common task, it can be challenging to display progress information without blocking both the server and client. This article discusses how to achieve this using a combination of server-side and client-side technologies.
Background
Consider an application where files are uploaded to a server using fetch(), with the body set to a Blob, File, TypedArray, or ArrayBuffer object. The goal is to read and echo the file size of the uploaded file in real time, so that the client can display progress as the file is being written on the server.
Server-Side Implementation (e.g., PHP)
The server-side implementation involves two scripts: 'data.php' for writing the file to the server and 'stream.php' for streaming the file size to the 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>
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>
Client-Side Implementation (e.g., JavaScript)
The client-side implementation uses fetch() to upload the file and an EventSource to receive the file size updates from the server.
<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>
Additional Considerations
To handle potential issues with file write or read, error handling mechanisms can be incorporated. Additionally, it's important to clear the file size cache to ensure accurate file size updates.
Conclusion
By following these steps, you can achieve real-time file size reading and echoing of uploaded files, without blocking the server or client. This enables seamless progress tracking for file uploads on both the client and server side.
The above is the detailed content of How to Read and Echo File Size of Uploaded File in Real Time?. For more information, please follow other related articles on the PHP Chinese website!

DependencyInjection(DI)inPHPenhancescodeflexibilityandtestabilitybydecouplingdependencycreationfromusage.ToimplementDIeffectively:1)UseDIcontainersjudiciouslytoavoidover-engineering.2)Avoidconstructoroverloadbylimitingdependenciestothreeorfour.3)Adhe

ToimproveyourPHPwebsite'sperformance,usethesestrategies:1)ImplementopcodecachingwithOPcachetospeedupscriptinterpretation.2)Optimizedatabasequeriesbyselectingonlynecessaryfields.3)UsecachingsystemslikeRedisorMemcachedtoreducedatabaseload.4)Applyasynch

Yes,itispossibletosendmassemailswithPHP.1)UselibrarieslikePHPMailerorSwiftMailerforefficientemailsending.2)Implementdelaysbetweenemailstoavoidspamflags.3)Personalizeemailsusingdynamiccontenttoimproveengagement.4)UsequeuesystemslikeRabbitMQorRedisforb

DependencyInjection(DI)inPHPisadesignpatternthatachievesInversionofControl(IoC)byallowingdependenciestobeinjectedintoclasses,enhancingmodularity,testability,andflexibility.DIdecouplesclassesfromspecificimplementations,makingcodemoremanageableandadapt

The best ways to send emails using PHP include: 1. Use PHP's mail() function to basic sending; 2. Use PHPMailer library to send more complex HTML mail; 3. Use transactional mail services such as SendGrid to improve reliability and analysis capabilities. With these methods, you can ensure that emails not only reach the inbox, but also attract recipients.

Calculating the total number of elements in a PHP multidimensional array can be done using recursive or iterative methods. 1. The recursive method counts by traversing the array and recursively processing nested arrays. 2. The iterative method uses the stack to simulate recursion to avoid depth problems. 3. The array_walk_recursive function can also be implemented, but it requires manual counting.

In PHP, the characteristic of a do-while loop is to ensure that the loop body is executed at least once, and then decide whether to continue the loop based on the conditions. 1) It executes the loop body before conditional checking, suitable for scenarios where operations need to be performed at least once, such as user input verification and menu systems. 2) However, the syntax of the do-while loop can cause confusion among newbies and may add unnecessary performance overhead.

Efficient hashing strings in PHP can use the following methods: 1. Use the md5 function for fast hashing, but is not suitable for password storage. 2. Use the sha256 function to improve security. 3. Use the password_hash function to process passwords to provide the highest security and convenience.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SublimeText3 Chinese version
Chinese version, very easy to use

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
