서버와 클라이언트를 차단하지 않고 서버측에 업로드된 파일의 크기를 실시간으로 읽고 인쇄하는 방법은 무엇입니까?
이 문제를 확장해 보겠습니다.
파일 업로드 진행 상황을 실시간으로 가져오기 위해 가져오기를 통해 Blob, File, TypedArray 또는 ArrayBuffer 개체에서 설정합니다. () POST 요청의 본문 개체입니다.
현재 구현에서는 File 객체를 body 객체에 전달된 fetch()의 두 번째 인수로 설정합니다.
요구 사항:
텍스트/이벤트 스트림은 서버의 파일 시스템에 기록되는 파일의 크기를 읽고 이를 클라이언트에 다시 에코합니다. GET 요청의 var 쿼리 문자열 매개변수가 제공한 모든 바이트가 기록되면 중지됩니다. 파일 읽기는 현재 파일을 읽는 스크립트에 대해 GET 호출이 수행된 다음 서버에 파일을 쓰는 스크립트에 대해 POST가 수행되는 별도의 스크립팅 환경에서 발생합니다.
현재 파일 크기를 가져오기 위해 서버 측 파일 쓰기 또는 파일 읽기 처리와 관련된 잠재적인 문제를 해결하기 전에 파일 크기 에코 부분을 완료할 때까지 기다리십시오.
현재 요구사항을 충족하기 위해 PHP를 사용하려고 합니다. 하지만 동일한 작업을 수행하는 데 사용할 수 있는 c, bash, nodejs, Python 또는 기타 언어나 방법에도 관심이 있습니다.
클라이언트측 자바스크립트 부분은 괜찮습니다. 나는 불필요한 부분을 포함하지 않고 패턴을 구현하는 PHP(세계에서 가장 널리 사용되는 서버 측 언어 중 하나)에 익숙하지 않습니다.
동기:
가져오기 진행률 표시기?
관련 항목:
ReadableStream으로 가져오기
질문:
가져오기
PHP Notice: Undefined index: HTTP_LAST_EVENT_ID in stream.php on line 7
터미널에서.
또한
while(file_exists($_GET["filename"]) && filesize($_GET["filename"]) < intval($_GET["filesize"]))
을
while(true)
으로 바꾸면 EventSource에서 오류가 발생합니다. <… 예상되는 결과는 업로드된 파일 객체의 파일 크기 대신
에 파일을 쓸 때 파일 크기를 가져오는 것입니다. fopen() 또는 stream_copy_to_stream()은 다른 PHP 프로세스가 stream.php에 액세스하는 것을 방지합니까?stream_copy_to_stream($input, $file);지금까지 시도한 작업:
php
$_POST, $_GET 및 $_FILE 너머: JavaScriptPHP 처리 Blob에서 인용// 能否合并 `data.php`、`stream.php` 为同一个文件? // 能否使用 `STREAM_NOTIFY_PROGRESS` // "Indicates current progress of the stream transfer // in bytes_transferred and possibly bytes_max as well" to read bytes? // do we need to call `stream_set_blocking` to `false` // data.php <?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"; ?>javascript
// stream.php <?php header("Content-Type: text/event-stream"); header("Cache-Control: no-cache"); header("Connection: keep-alive"); // `PHP Notice: Undefined index: HTTP_LAST_EVENT_ID in stream.php on line 7` ? $lastId = $_SERVER["HTTP_LAST_EVENT_ID"] || 0; if (isset($lastId) && !empty($lastId) && is_numeric($lastId)) { $lastId = intval($lastId); $lastId++; } // else { // $lastId = 0; // } // while current file size read is less than or equal to // `$_GET["filesize"]` of `$_GET["filename"]` // how to loop only when above is `true` while (true) { $upload = $_GET["filename"]; // is this the correct function and variable to use // to get written bytes of `stream_copy_to_stream($input, $file);`? $data = filesize($upload); // $data = $_GET["filename"] . " " . $_GET["filesize"]; if ($data) { sendMessage($lastId, $data); $lastId++; } // else { // close stream // } // not necessary here, though without thousands of `message` events // will be dispatched // sleep(1); } function sendMessage($id, $data) { echo "id: $id\n"; echo "data: $data\n\n"; ob_flush(); flush(); } ?>
위 내용은 서버와 클라이언트를 차단하지 않고 서버에서 업로드된 파일의 현재 쓰기 크기를 실시간으로 읽고 에코하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!