后端接口返回的文件流,前端通过blob转换url下载文件(兼容ie)

1.接口请求:

let params = {
  id: 1,
  name: '李四'
}
this.$axios.post('/xxxx', params, { responseType: 'blob' }).then(res => {
  if (res.data) {
    this.fileDownLoad(res.data, 'text.xlsx')
  }
}).catch(() => {
  this.$message.error('下载失败')
})

注意:responseType:’blob’要加上,这样就会返回Blob对象,不然就会出现下载的xlsx在试图打开文件时遇到错误的问题。
在这里插入图片描述
responseType:设置该值能够改变响应类型,就是告诉服务器你期望的响应格式。

DOMString (这个是默认类型)
’ ’DOMString (这个是默认类型)
arraybufferArrayBuffer对象
blobBlob对象
documentDocument对象
jsonJavaScript object, parsed from a JSON string returned by the server
textDOMString

ps:不知道为什么我使用responseType: 'arraybuffer’也可以下载正确的格式,但是同一个接口同事要使用’blob’才可以。

2.blob转换URL方法:

fileDownLoad (data, name) {
  // 判断浏览器是否支持blob对象
  try {
    // 该实例化的方式第一个参数必须是数组的格式
    var blob = new Blob([data], { type: name })
  } catch (e) {
    // 旧版本浏览器下的blob创建对象
    window.BlobBuilder = window.BlobBuilder ||
                        window.WebKitBlobBuilder ||
                        window.MozBlobBuilder ||
                        window.MSBlobBuilder
    if (e.name === 'TypeError' && window.BlobBuilder) {
      var blobbuilder = new BlobBuilder()
      BlobBuilder.append(data)
      var blob = blobbuilder.getBlob("application/zip")
    } else {
      alert('浏览器版本较低,暂不支持该文件类型下载')
    }
  }
 	if (!!window.ActiveXObject || 'ActiveXObject' in window) { //判断了有该方法即为IE浏览器
    try {
      window.navigator.msSaveBlob(blob, name)
    } catch (e) {
      console.log(e);
    }
  } else {
    var url = window.URL.createObjectURL(blob)
    var linkElement = document.createElement('a') // 创建点击下载的元素
    linkElement.setAttribute('href', url)
    linkElement.setAttribute('downLoad', name)
    linkElement.click()
  }
},

3.结果展示(浏览器会直接下载):

在这里插入图片描述

前端下载 Excel 文件后端需要返回文件,可以按照以下步骤进行处理: 1. 后端根据前端请求参数,生成 Excel 文件,并将文件返回前端。 2. 前端通过 AJAX 发送请求,请求后端生成 Excel 文件接口。 3. 后端在接收到请求后,使用相关的库(如 Apache POI)生成 Excel 文件,并将文件返回前端。 4. 前端在接收到后端返回文件后,使用 Blob 对象创建一个 URL,并将该 URL 赋给一个 a 标签的 href 属性。 5. 前端再使用 JavaScript 触发该 a 标签的 click 事件,即可下载 Excel 文件。 以下是一个示例的后端代码,使用了 Spring Boot 和 Apache POI 库: ```java @GetMapping("/downloadExcel") public ResponseEntity<byte[]> downloadExcel() throws IOException { // 创建 Excel 工作簿 Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("Sheet1"); // 创建表头 Row header = sheet.createRow(0); header.createCell(0).setCellValue("姓名"); header.createCell(1).setCellValue("年龄"); // 创建数据行 Row dataRow = sheet.createRow(1); dataRow.createCell(0).setCellValue("张三"); dataRow.createCell(1).setCellValue(20); // 将 Excel 文件写入字节数组输出 ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); workbook.write(outputStream); // 设置响应头 HttpHeaders headers = new HttpHeaders(); headers.add("Content-Disposition", "attachment;filename=test.xlsx"); headers.setContentType(MediaType.APPLICATION_OCTET_STREAM); // 返回响应实体 return new ResponseEntity<>(outputStream.toByteArray(), headers, HttpStatus.OK); } ``` 在前端中,可以使用以下代码实现下载: ```javascript axios.get('/downloadExcel', { responseType: 'blob' }).then(res => { const blob = new Blob([res.data], { type: 'application/vnd.ms-excel' }) const url = URL.createObjectURL(blob) const a = document.createElement('a') a.href = url a.download = 'test.xlsx' a.click() URL.revokeObjectURL(url) }) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值