成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

ajax實現excel報表導出

瀏覽:384日期:2022-06-11 16:50:10

利用ajax實現excel報表導出【解決亂碼問題】,供大家參考,具體內容如下

背景

項目中遇到一個場景,要導出一個excel報表。由于需要token驗證,所以不能用a標簽;由于頁面復雜,所以不能使用表單提交。初步考慮前端使用ajax,后端返回流,定義指定的header。

第一版

主要代碼

前端

使用jquery的ajax

var queryParams = {"test":"xxx"};
var url = "xxx";
$.ajax({
 type : "POST", //提交方式
 url : url,//路徑
 contentType: "application/json",
 data: JSON.stringify(queryParams),
 beforeSend: function (request) {
  request.setRequestHeader("Authorization", "xxx");
 },
 success : function(result) {
  const blob = new Blob([result], {type:"application/vnd.ms-excel"});
  if(blob.size < 1) {
   alert("導出失敗,導出的內容為空!");
   return
  }
  if(window.navigator.msSaveOrOpenBlob) {
   navigator.msSaveOrOpenBlob(blob, "test.xls")
  } else {
   const aLink = document.createElement("a");
   aLink.style.display = "none";
   aLink.href = window.URL.createObjectURL(blob);
   aLink.download = "test.xls";
   document.body.appendChild(aLink);
   aLink.click();
   document.body.removeChild(aLink);
  }
 }
});

后端

使用easypoi(如何使用easypoi請自行百度)

import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams;

@PostMapping(value = "/download")
public void downloadList(@RequestBody Objct obj, HttpServletResponse response) {

 ......

 List<Custom> excelList = new ArrayList<>();
 
   // excel總體設置
   ExportParams exportParams = new ExportParams();
   // 指定sheet名字
   exportParams.setSheetName("test");
   Workbook workbook = ExcelExportUtil.exportExcel(exportParams, Custom.class, excelList);
 
   response.setContentType("application/vnd.ms-excel");
   response.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("test", "utf-8") + ".xls");
   OutputStream outputStream = response.getOutputStream();
   workbook.write(outputStream);
   outputStream.flush();
   outputStream.close();
   
 ......
 
}

測試結果

excel能正常導出,但下載下來的excel全是亂碼。經過各種找答案,整理了一下可能是以下原因導致:

1、后端未設置字符集,或者在spring框架的過濾器中統一設置了字符集;
2、前端頁面未設置字符集編碼;
3、需要在ajax中添加 request.responseType = “arraybuffer”;

經過不斷測試,我的應該是第三點導致。但在jquery ajax 中添加后仍然不起作用,亂碼問題始終無法解決。

第二版

主要代碼

前端,使用原生的ajax。后端未變動。

var xhr = new XMLHttpRequest();
xhr.responseType = "arraybuffer"; 
xhr.open("POST", url, true);
xhr.onload = function () {
 const blob = new Blob([this.response], {type:"application/vnd.ms-excel"});
 if(blob.size < 1) {
  alert("導出失敗,導出的內容為空!");
  return;
 }
 if(window.navigator.msSaveOrOpenBlob) {
  navigator.msSaveOrOpenBlob(blob, "test.xls")
 } else {
  const aLink = document.createElement("a");
  aLink.style.display = "none";
  aLink.href = window.URL.createObjectURL(blob);
  aLink.download = "testxls";
  document.body.appendChild(aLink);
  aLink.click();
  document.body.removeChild(aLink);
  return;
 }
}
xhr.setRequestHeader("Authorization", "xxx");
xhr.setRequestHeader("Content-Type", "application/json");
xhr.send(JSON.stringify(queryParams));

測試結果

下載的excel不再亂碼,原生ajax中使用 “arraybuffer” 使用是生效的。

總結

“arraybuffer” 這個參數導致的excel導出亂碼,在原生的ajax中設置是有效的,在jquery的ajax中暫時還沒找到生效的方式。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。

標簽: Ajax
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美日韩视频一区二区三区| 亚洲v精品v日韩v欧美v专区| 国产日韩欧美制服另类| 久久黄色级2电影| 欧美综合在线视频| 精品亚洲欧美一区| 91 com成人网| 国产91富婆露脸刺激对白| 欧美精品一二三区| 国产河南妇女毛片精品久久久| 91精品国产综合久久福利| 国产成人av电影| 久久奇米777| 亚洲经典三级| 亚洲一区二区美女| 色婷婷国产精品| 国产一区二区毛片| 国产视频亚洲色图| 国产精品视频久久一区| 日本成人在线视频网站| 91精品国产欧美一区二区18| 亚洲激情第一区| 色哟哟亚洲精品| 国产精品18久久久久| 国产欧美日韩在线看| 在线一区视频| 激情综合色播五月| 国产视频一区在线播放| 国产精品婷婷| 国产高清无密码一区二区三区| 国产日韩欧美一区二区三区综合| 亚洲影院在线| 成人午夜私人影院| 7777精品伊人久久久大香线蕉的| 国产一区二区女| 日韩视频中午一区| 成人小视频免费在线观看| 精品国产第一区二区三区观看体验 | 国产亚洲毛片在线| 午夜精品一区二区三区电影天堂| 久久夜色精品| 日韩成人伦理电影在线观看| 欧美无砖砖区免费| 一区二区三区国产盗摄 | 日韩亚洲欧美成人一区| 欧美私人啪啪vps| 日韩中文字幕一区二区三区| 欧美精品一区二区三区在线| 另类综合日韩欧美亚洲| 国产精品v欧美精品v日韩 | 国产精品色哟哟网站| 日韩一级在线| 午夜日韩在线观看| 欧美精品aⅴ在线视频| 国产成人亚洲综合a∨猫咪| 精品欧美黑人一区二区三区| 狠狠干成人综合网| 亚洲国产日韩av| 欧美日韩中文国产| 丁香五精品蜜臀久久久久99网站| 国产亚洲精久久久久久| 一本一道久久综合狠狠老精东影业 | 欧美一区二区黄色| 91色|porny| 中文字幕在线不卡| 噜噜噜躁狠狠躁狠狠精品视频| 蜜臀91精品一区二区三区| 日韩写真欧美这视频| 欧美午夜电影在线观看 | 国产成人精品免费网站| 久久精品亚洲精品国产欧美| 在线日韩视频| 青椒成人免费视频| 精品久久国产字幕高潮| 亚洲看片免费| 久久www免费人成看片高清| 久久精品人人做人人爽97| 国产日韩欧美一区二区三区在线观看 | 成人开心网精品视频| 亚洲欧美日韩国产手机在线| 色天使久久综合网天天| 成人综合激情网| 亚洲午夜激情网站| 强制捆绑调教一区二区| 3d动漫精品啪啪| 欧美日韩免费一区二区三区视频| 亚洲欧美日韩在线观看a三区 | 久久高清国产| 99精品欧美一区二区三区| 国内揄拍国内精品久久| 99精品国产视频| 国产成人h网站| 秋霞电影一区二区| 久久久99精品久久| www国产精品av| 精品久久久久久久久久久院品网 | 亚洲精品成人在线| 亚洲欧洲一区二区在线播放| 欧美午夜精彩| 麻豆一区二区99久久久久| 国产精品网站在线观看| 色美美综合视频| 狠狠色综合网站久久久久久久| 日本女人一区二区三区| 久久久久久亚洲综合| 欧美性做爰猛烈叫床潮| 合欧美一区二区三区| 国产电影一区二区三区| 亚洲精品免费在线| 亚洲精品在线三区| 91成人在线精品| 亚洲综合激情另类小说区| 亚洲一区二区视频在线| 亚洲男人的天堂网| 亚洲国产精品麻豆| 轻轻草成人在线| 国产精品一区二区三区网站| 国产精品女主播av| 国产欧美一区二区三区鸳鸯浴| 国产日韩欧美综合一区| **性色生活片久久毛片| 亚洲第一搞黄网站| 久久毛片高清国产| 欧美另类变人与禽xxxxx| 国产欧美91| 欧美fxxxxxx另类| 精品一区二区日韩| 亚洲一区二区三区四区的| 欧美极品另类videosde| 777奇米成人网| 在线观看国产日韩| 99综合精品| 色综合天天综合网国产成人综合天| 日韩在线卡一卡二| 中文字幕一区二区三区在线播放| 日韩一区二区三区三四区视频在线观看 | 国内在线观看一区二区三区| 国产精品一区二区在线观看网站| 亚洲黄色小视频| 中文字幕免费一区| 91精品国产综合久久精品麻豆| 久久天堂成人| 一区二区国产日产| 亚洲欧美在线网| 成人午夜在线视频| 久久国产精品色| 午夜精品久久一牛影视| 中文字幕中文字幕一区二区| 精品日韩99亚洲| 欧美一区日本一区韩国一区| 色偷偷成人一区二区三区91| 国产精品一级久久久| 欧美三级小说| 9色porny自拍视频一区二区| 国产精品77777| 免费精品视频最新在线| 五月开心婷婷久久| 亚洲色图欧美在线| 欧美国产禁国产网站cc| 欧美精品一区二区久久久| 欧美日韩亚洲综合在线| 一本大道久久a久久综合| 国产精品一卡| 99精品国产福利在线观看免费| 国内精品久久久久久久果冻传媒 | 国产麻豆日韩欧美久久| 日韩国产欧美在线观看| 亚洲国产另类av| 亚洲男同1069视频| 自拍偷拍欧美精品| 最新国产精品久久精品| 中文字幕国产一区| 久久精子c满五个校花| 26uuu亚洲综合色| 欧美一区二区视频网站| 欧美一区中文字幕| 欧美精品免费视频| 欧美一区二区三区成人| 91精品国产综合久久久蜜臀图片 | 久久久亚洲高清| 久久久久久久久蜜桃| 欧美精品一区二区三区在线| 久久综合999| 久久久久久99精品| 久久久久久久久久久久久女国产乱 | 成人午夜视频免费看| 大陆成人av片| 国产成人精品免费一区二区| 国产91精品免费| 成人国产一区二区三区精品| 不卡视频在线看| 91香蕉视频污在线| 欧美日韩久久| 精品99视频| 99精品视频免费观看视频| 亚洲在线网站| 美女精品国产| 欧美日韩三级一区二区| 欧美一区二区三区在线观看| 久久人人爽人人爽|