angular 2 通过http get 下载excel 内容错误

本文介绍了一个关于从服务器导出Excel文件时遇到的问题:尽管二进制内容正确,但文件却无法正常打开。文章详细解释了如何通过设置HTTP请求的responseType属性为Blob来解决此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务端代码:

  public ResponseEntity<Resource> exportsequence(@PathVariable String modelname) throws IOException {
        XSSFWorkbook  wb = constructExportData(modelname);
        ByteArrayOutputStream os = new ByteArrayOutputStream();
        wb.write(os);
        InputStreamResource resource = new InputStreamResource(os.toInputStream());
        os.close();
        return ResponseEntity.ok().contentType(MediaType.valueOf("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")).body(resource);
    }
    /**
     *
     *
     * @param modelName
     */
    private XSSFWorkbook constructExportData(String modelName) {
        XSSFWorkbook  wb = new XSSFWorkbook();
        XSSFSheet sheet = wb.createSheet(ExcelFileHandlerUtil.SEQUENCE_SHEET_FC);
        XSSFRow row = sheet.createRow(0);
        XSSFCell cell = row.createCell(0);
        cell.setCellValue(ExcelFileHandlerUtil.MODEL_STRING);



        return wb;
    }

 

客户端代码:

return this.http.get(`${this.resourceUrl}/exportsequence/${modelName}`);

用这个下载的时候二进制内容都是正确的,可是打开文件老报错,打不开。

原来要在请求上加一个   responseType

修改代码如下:

const requestOptions = {
    responseType: ResponseContentType.Blob
};

return this.http.get(`${this.resourceUrl}/exportsequence/${modelName}`, requestOptions);

记得加:

import {Http, Response,ResponseContentType } from '@angular/http';

 

 

 

 

转载于:https://my.oschina.net/u/241688/blog/1839198

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值