No auto-decompression of gzipped json on browser&#

2019-04-11 13:22发布

问题:

I'm trying to load a json file using angular (v1.2.6):

$http.get('myfile.json').success(function(data) { ... }

This works fine, except when I create a (static) compressed version of the file on the server, and try to load 'myfile.json.gz' instead (to reduce the loading time).

The request headers seem correct (Chrome 31.0 on Mac) (as stated here and here):

Accept: application/json, text/plain, */*
Accept-Encoding: gzip,deflate,sdch

while the response headers contain:

Connection: close
Accept-Ranges: bytes
Content-Length: 702468
Content-Type: application/x-gzip
Content-Encoding: gzip

However, the content is not automatically decompressed by the client browser, as I understand it should be. data.length is ~700Kb instead of the original uncompressed ~3Mb.

Although this one post suggests it needs to be done manually, I understand decompression should be automatic and transparent.

My question is, should it be decompressed automatically? and why isn't it the case here?

回答1:

Your content type should not be "application/x-gzip* it should stay : application/json

The content encoding is enough to say to the browser that the content is zipped.

What HTTP server are you running ? You should configure it in order to return the correct mime type, regardless of the .gz extension.