2017-07-10 33 views
1

我正在創建一個使用腳本FileSaver.js(https://github.com/eligrey/FileSaver.js)來使用戶下載OpenXML文件的網頁。Firefox向OpenXML電子表格文件添加了錯誤的擴展,並且設置了良好的MIME類型

下面是下載使用Ajax的文件中的函數,解壓縮,然後讓用戶下載:

function dlExcel(){ 
    var bOk = true; 
    try { 
     var isFileSaverSupported = !!new Blob; 
    } catch (e) { 
    bOk = false; 
     alert("Votre navigateur ne supporte pas l'expore des fichiers excel, veuillez le metre à jour."); 
    } 
    var oReq = new XMLHttpRequest(); 
    oReq.open("GET", "AJXExcel.aspx", true); 
    oReq.responseType = "arraybuffer"; 

    oReq.onload = function (oEvent) { 
     if (oReq.status == 503){ 
      alert("Une erreur est survenue"); 
     } 
     else if (oReq.status == 208){ 
      alert("Le fichier demandé comporte trop de ligne, veuillez affiner votre recherche à l'aide des filtres poposé"); 
     }else{ 
      var arrayBuffer = new Uint8Array(oReq.response); 
      var gunzip = new Zlib.Gunzip(arrayBuffer); 
      var plain = gunzip.decompress(); 
      var blob = new Blob([plain], { 
       "type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" 
      }); 
      if(oReq.status == 206) 
       alert("Le fichier généré comportait trop de lignes, il a donc été tronqué"); 
      saveAs(blob,"resultats.xml"); 
     } 
     document.getElementById("ctl00_ctl00_MenuContentPlaceHolder_MainContentPlaceHolder_loading").style.display = "none"; 
     document.getElementById("ctl00_ctl00_MenuContentPlaceHolder_MainContentPlaceHolder_param").style.display = "block"; 
    } 
    if (bOk){ 
     oReq.send(null); 
    } 
} 

我曾嘗試使用XML編輯器(在許多MIME類型和擴展,他們要麼開軟從辦公室,決定用軟打開XML文件)或直接與Excel(我想要的),但Firefox添加.xml後的.xls,以便使excel拒絕打開一個file.xLs.xml。

我在網上找不到類似的問題,所以如果我至少可以對造成這種問題的想法有所瞭解,我將不勝感激!

我一開始想到Windows註冊表,但這個問題似乎只發生在Firefox上。

+1

我在這裏找到了一個類似的帖子[SO post](https://stackoverflow.com/questions/45009711/firefox-add-wrong-extention-to-openxml-spreadsheet-file-with-supposed-good-mime)看起來似乎有一個報告的錯誤 –

回答

相關問題