• Springboot +vue 实现导出功能


    最近在工作遇到vue和Springboot 实现导出功能,翻看很多资料,发现一些博客写法都过时了,所以自己特此记录下,使用版本vue2,Springboot 2x以上,chrome浏览器  76.0.3809.100

    vue 2写法

     let blob = new Blob([res.data], { type: 'application/octer-stream' });

     其中我发现很多博客用这样的写法,但是我发现打印res的时候没有发现data这个参数,总是报错后面直接用res就好了。

     正确写法let blob = new Blob([res], { type: 'application/octer-stream' });

     科普一下:axios中params和data两者,以为他们是相同的,实则不然。 因为params是添加到url的请求字符串中的,而data是添加到请求体(body)中的,最好使用params参数

    import axios from 'axios'
    
    axios({
      method: 'post',
      url: '/user/excelExport',
      responseType:‘blob’,
      params
    }).then(res => {
    
    const link = document.createElement('a')
    
    let blob = new Blob([res], { type: 'application/octer-stream' });
    
    link.style.display = 'none'
    
    link.href = URL.createObjectURL(blob);
    
    link.setAttribute('download', fileName + '.xlsx');
    
    document.body.appendChild(link);
    
    link.click();
    
    document.body.removeChild(link);
    
    }).catch(err => {
    
    console.log(err)
    
    });

    后台代码写法 ——使用阿里巴巴的excel导出类easyexcel ——https://github.com/alibaba/easyexcel

    <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>{latestVersion}</version>
    </dependency>

          //这里可以不用关闭流,流在方法结束,会自动关闭,通过配置product,指定返回头
    @PostMapping(path = "/user/excelExport", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE) public void excelExport(WithdrawListDto withdrawListDto, HttpServletResponse response) { List<WithdrawListVo> list = withdrawService.list(withdrawListDto); ExcelWriter writer = new ExcelWriter(response.getOutputStream(), ExcelTypeEnum.XLSX, true); Sheet sheet1 = new Sheet(1, 0, WithdrawListVo.class); sheet1.setSheetName("sheet1"); writer.write(list, sheet1); }

    反过来推导入,也可以用这种方式,并且支持多参数,当加入MultipartFile 对象,SpringBoot 可以自己识别图片类型,不需要在PostMapping,加上返回头了。前端传过来的context-Type 要加上multipart/form-data 类型,然后在前端传过来的url进行拼接参数,就可以进行多参数,但是不建议参数太多

    例子:如/user/excelImport?account=12731564&userName=李四


    @PostMapping(path = "/user/excelImport") public void excelImport(WithdrawListDto withdrawListDto,MultipartFile multipartFile) {


    }
    multipart/form-data
  • 相关阅读:
    内存泄漏检测工具VLD在VS2010中的使用举例
    boost::threadpool 调用类成员变量并传入参数 的方法
    boost之ThreadPool
    DllMain 用法
    分布式锁的几种实现方式
    利用cbmakegen导出Code::blocks的Makefile
    搜集C++实现的线程池
    微软开源rDSN分布式系统开发框架
    腾讯互娱开源分布式开发框架Pebble
    SpringBoot指定额外需要扫描的包
  • 原文地址:https://www.cnblogs.com/uqing/p/11363665.html
Copyright © 2020-2023  润新知