총 파일 크기를 모르고 XMLHttpRequest에서 다운로드 진행 상황을 어떻게 추적합니까?

Mary-Kate Olsen
풀어 주다: 2024-10-28 17:56:02
원래의
123명이 탐색했습니다.

How do you track download progress in XMLHttpRequest without knowing the total file size?

XMLHttpRequest의 진행 상황 모니터링

XMLHttpRequest(XHR)는 JavaScript에서 비동기 요청을 수행하기 위한 메커니즘을 제공합니다. xhr.upload.onprogress 이벤트를 사용하여 업로드 진행률 추적을 지원하지만, 수신할 총 바이트에 대한 정보가 부족하기 때문에 다운로드 진행률을 얻는 것이 그리 간단하지 않습니다.

업로드 진행률 추적

업로드 진행 상황을 확인하는 방법은 비교적 간단합니다. 브라우저는 업로드되는 파일의 크기와 전송되는 데이터의 양에 대한 정보를 유지하므로 xhr.upload.onprogress 이벤트를 통해 진행률을 파생할 수 있습니다.

다운로드 진행률 모니터링

다운로드의 경우 브라우저가 들어오는 데이터의 크기를 알 수 없기 때문에 문제가 발생합니다. 그러나 이는 전송할 데이터의 총 크기를 지정하는 서버 응답에 Content-Length 헤더를 설정하여 극복할 수 있습니다.

서버측 구성

서버측 콘텐츠 전달을 담당하는 코드는 다운로드되는 파일 또는 데이터의 크기에 따라 Content-Length 헤더를 설정해야 합니다. 예:

$filesize = filesize('test.zip');

header("Content-Length: " . $filesize); // Set header length
readfile('test.zip');
exit 0;
로그인 후 복사

클라이언트측 구현

Content-Length 헤더가 설정된 경우 클라이언트측 코드는 이제 다운로드 진행률을 추적할 수 있습니다.

function updateProgress(evt) {
  if (evt.lengthComputable) {
    // evt.loaded: Bytes received by the browser
    // evt.total: Total bytes defined by the header
    var percentComplete = (evt.loaded / evt.total) * 100;
    $('#progressbar').progressbar("option", "value", percentComplete);
  }
}

function sendreq(evt) {
  var req = new XMLHttpRequest();
  $('#progressbar').progressbar();
  req.onprogress = updateProgress;
  req.open('GET', 'test.php', true);
  req.onreadystatechange = function (aEvt) {
    if (req.readyState == 4) {
      // Callback actions here
    }
  };
  req.send();
}
로그인 후 복사

이 코드는 jQuery UI 라이브러리를 사용하여 데이터가 수신될 때 진행률을 표시하는 진행률 표시줄을 만듭니다. Content-Length 헤더를 활용하면 브라우저에서 다운로드 진행률을 정확하게 계산하고 표시할 수 있으므로 시각적 진행률 표시기가 필요한 대용량 파일 다운로드에 유용합니다.

위 내용은 총 파일 크기를 모르고 XMLHttpRequest에서 다운로드 진행 상황을 어떻게 추적합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!