我正在創建一個使用腳本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上。
我在這裏找到了一個類似的帖子[SO post](https://stackoverflow.com/questions/45009711/firefox-add-wrong-extention-to-openxml-spreadsheet-file-with-supposed-good-mime)看起來似乎有一個報告的錯誤 –