使用AJAX加载GZIP JSON文件

时间:2013-04-02 15:27:00

标签: javascript ajax json gzip

我使用以下算法(来自:java gzip can't keep original file's extension name

使用gzip压缩json文件
private static boolean compress(String inputFileName, String targetFileName){
         boolean compressResult=true;
         int BUFFER = 1024*4;
         byte[] B_ARRAY = new byte[BUFFER]; 
         FileInputStream fins=null;
         FileOutputStream fout=null;
         GZIPOutputStream zout=null;
         try{
             File srcFile=new File(inputFileName);
             fins=new FileInputStream (srcFile);
             File tatgetFile=new File(targetFileName);
             fout = new FileOutputStream(tatgetFile);
             zout = new GZIPOutputStream(fout);
             int number = 0; 
             while((number = fins.read(B_ARRAY, 0, BUFFER)) != -1){
                 zout.write(B_ARRAY, 0, number);  
             }
         }catch(Exception e){
             e.printStackTrace();
             compressResult=false;
         }finally{
             try {
                zout.close();
                fout.close();
                fins.close();
            } catch (IOException e) {
                e.printStackTrace();
                compressResult=false;
            }
         }
         return compressResult;
    }

我正在返回JSON

response.setHeader("Content-Type", "application/json");
response.setHeader("Content-Encoding", "gzip");
response.setHeader("Vary", "Accept-Encoding");
response.setContentType("application/json");
response.setHeader("Content-Disposition","gzip");
response.sendRedirect(filePathurl);

request.getRequestDispatcher(filePathurl).forward(request, response);

尝试使用AJAX代码访问JSON对象,如下所示:

$.ajax({
    type : 'GET',
    url : url,
    headers : {'Accept-Encoding' : 'gzip'},
    dataType : 'text',

我看到的输出是二进制数据,而不是解压缩的JSON字符串。有关如何使这项工作的任何建议? 请注意,我正在使用的浏览器(IE,Chrome,FF)支持gzip,因为我的所有静态内容都被Apache正确呈现。

1 个答案:

答案 0 :(得分:2)

使用:

response.sendRedirect(filePathurl);

您正在创建另一个请求/响应。您定义的标头不再与实际发送的文件相关联。

您需要加载文件并将其流式传输到同一响应中,而不是发送重定向。

使用Fiddler或其他请求查看器查看此内容。