Ajax - Get size of file before downloading Ajax - Get size of file before downloading ajax ajax

Ajax - Get size of file before downloading


You can get XHR response header data manually:

http://www.w3.org/TR/XMLHttpRequest/#the-getresponseheader()-method

This function will get the filesize of the requested URL:

function get_filesize(url, callback) {    var xhr = new XMLHttpRequest();    xhr.open("HEAD", url, true); // Notice "HEAD" instead of "GET",                                 //  to get only the header    xhr.onreadystatechange = function() {        if (this.readyState == this.DONE) {            callback(parseInt(xhr.getResponseHeader("Content-Length")));        }    };    xhr.send();}get_filesize("http://example.com/foo.exe", function(size) {    alert("The size of foo.exe is: " + size + " bytes.");});


Sometimes HEAD can act differently than GET so I suggest something like this that aborts the request after getting Content-Length header:

new Promise(resolve => {    var xhr = new XMLHttpRequest();    xhr.open('GET', '/a.bin', true);    xhr.onreadystatechange = () => {        resolve(+xhr.getResponseHeader("Content-Length"));        xhr.abort();    };    xhr.send();}).then(console.log);


If HEAD request is not possible:

The solution Ebrahim did only not work in firefox for me because context-length was not available for aborted request in firefox. So I used 'onprogress' event instead of 'onreadystatechange' event:

new Promise(  (resolve, reject) => {    var xhr = new XMLHttpRequest();    xhr.open('GET', url, true);    xhr.onprogress = (event) => {      if (event.lengthComputable) {        resolve(event.total);      } else {        reject(new Error('No content-length available'));      }      xhr.abort();    };    xhr.send();  });