easyexcel实现导出excel文件到s3服务器

常见的做法一般是直接通过请求接口响应对象response把文件输出
java 复制代码
/**
     * 导出列表
     *
     * @param request
     * @param response
     */
    @Override
    public void export(AuctionRequest request, HttpServletResponse response) throws IOException {
        Map<String, Object> queryMap = Maps.newHashMap(BeanConvertUtils.beanToMap(request));
        List<Auction> auctions = auctionManager.listAuctions(queryMap);
        if (CollectionUtils.isEmpty(auctions)) {
            throw new AuctionException("当前数据为空");
        }

        List<AuctionDataExportModel> auctionExportModels = auctions.stream().map(item -> {
            AuctionDataExportModel auctionExportModel = new AuctionDataExportModel();
            auctionExportModel.setAuCode(item.getAuCode());
            auctionExportModel.setAuTitle(item.getAuTitle());
         
            return auctionExportModel;
        }).collect(Collectors.toList());

        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setCharacterEncoding("utf-8");
        String fileName = URLEncoder.encode("导出", "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + System.currentTimeMillis() + ".xlsx");
        EasyExcel.write(response.getOutputStream(), AuctionDataExportModel.class).sheet("数据区").doWrite(auctionExportModels);

    }

这样操作乍一看没啥问题.但是我这边前端同事是使用的axios发送的请求,必须指定响应类型为 'arraybuffer' 或者 'blob'.

javascript 复制代码
axios({
  method: 'post',
  url: '/export',
  responseType: 'arraybuffer',//'blob'
}).then(res => {})

正常下载是没有问题的,一旦代码报错.因为指定了响应类型.就拿不到返回的错误信息了.

于是采用了成功的时候后端直接把文件上传到s3服务器,然后把文件地址返给前端.出错的时候把错误信息返给前端,就解决了上述的问题

直接上代码

java 复制代码
/**
     * 导出列表
     *
     * @param request
     */
    @Override
    public String export(AuctionRequest request) {
        Map<String, Object> queryMap = Maps.newHashMap(BeanConvertUtils.beanToMap(request));
        List<Auction> auctions = auctionManager.listAuctions(queryMap);
        if (CollectionUtils.isEmpty(auctions)) {
            throw new AuctionException("当前数据为空");
        }

        List<AuctionDataExportModel> auctionExportModels = auctions.stream().map(item -> {
            AuctionDataExportModel auctionExportModel = new AuctionDataExportModel();
            auctionExportModel.setAuCode(item.getAuCode());
            auctionExportModel.setAuTitle(item.getAuTitle());
            
            return auctionExportModel;
        }).collect(Collectors.toList());


        //上传至s3服务器,同时将路径返回给前台
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        EasyExcel.write(bos, AuctionDataExportModel.class).sheet("数据区").doWrite(auctionExportModels);
        byte[] binary = bos.toByteArray();
        InputStream inputStream = new ByteArrayInputStream(binary);
        String excelName = "导出" + IdWorker.getMillisecond() + ".xls";
        String returnFilePath = CommonsConstants.STORE_AUCTION_SYNC_EXCEL + excelName;
        PutObjectResult putObjectResult = s3Util.uploadFile(inputStream, "xls", returnFilePath);
        org.wildfly.common.Assert.assertNotNull(putObjectResult);
        return returnFilePath;

    }
相关推荐
Evan芙12 小时前
用fping编写脚本扫描10.0.0.0/24网段在线主机
linux·运维·网络·excel
SamDeepThinking17 小时前
基于CompletableFuture的主子任务并行处理架构实战:多渠道账单并发导入性能提升5倍的技术方案
java·后端·excel
SamDeepThinking17 小时前
88MB Excel文件导致系统崩溃?看我如何将内存占用降低
java·excel
ChrisitineTX18 小时前
警惕数据“陷阱”:Python 如何自动发现并清洗 Excel 中的异常值?
开发语言·python·excel
wtsolutions18 小时前
Excel to JSON by WTSolutions 4.0.0 版本更新公告
json·excel·wps·插件·转换·加载项·wtsolutions
wtsolutions18 小时前
Excel to JSON by WTSolutions 4.0.0 Update Announcement
json·excel·wps·addin·wtsolutions·conversion
癫狂的兔子2 天前
【Office】【Excel】常用函数公式总结
excel
毛飞龙2 天前
Excel迷你图:在单元格中嵌入趋势洞察
excel·迷你图·sparklines
Tatalaluola2 天前
Unity使用EPPlus读取写入表格
unity·c#·游戏引擎·excel
缺点内向2 天前
如何在 C# 中将 Excel 工作表拆分为多个窗格
开发语言·c#·.net·excel