vue sprigboot 后端导出excel(一)简单测试例子

后端:
1.依赖:

 <!--easyPOI依赖-->
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-spring-boot-starter</artifactId>
            <version>4.1.3</version>
            <exclusions>
                <exclusion>
                    <artifactId>guava</artifactId>
                    <groupId>com.google.guava</groupId>
                </exclusion>
            </exclusions>
        </dependency>

controller:接口

/**
     * 下载excel文档(2)
     * 最新接口:后端导出
     * @param
     */
    @GetMapping(value = "/exportExcel", produces = "application/octet-stream")
    @ApiOperation(value = "导出Excel数据")
    public void exportExcel(HttpServletRequest request, HttpServletResponse response) throws IOException {

        System.out.println("downLoadExcel接口================================start");

        long start = System.currentTimeMillis();
        //1.获取商品数据list
        List<Ware> wareList = iWareService.list();

        int totalNum = wareList.size();
        //log.info("导出商品列表excel-数据量:{}",wareList.size());
        //导出
        //HSSF:03版本:后缀:xls //速度快兼容好
        //XSSF:07版本:后缀:.xlsx
        ExportParams params = new ExportParams("商品统计", "商品统计", ExcelType.HSSF);

        Workbook workbook = ExcelExportUtil.exportExcel(params, ware.class, wareList);

        //准备一个流开始响应
        ServletOutputStream outputStream = null;
        try {
            //流形式
            response.setHeader("content-type", "application/octet-stream");
            //设置文件名字以及防止中文乱码
            response.setHeader("content-disposition", "attachment;filename=" +
                    URLEncoder.encode("商品统计.xls", "UTF-8"));
            outputStream = response.getOutputStream();
            workbook.write(outputStream);
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (ObjectUtil.isNotNull(outputStream)) {
                try {
                    outputStream.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        //访问接口时间
        long end = System.currentTimeMillis();
        log.info("导出商品列表excel-请求客户端:{},数据量:{}条,耗时:{}ms", Iputils.getIP(request), totalNum, (end - start) * 0.001);

        //returnMap.put("status","00");
        System.out.println("downLoadExcel接口================================end");
        //return returnMap;
    }

工具类:

import com.baomidou.mybatisplus.core.toolkit.StringUtils;

import javax.servlet.http.HttpServletRequest;

public class Iputils {
    public static String getIP(HttpServletRequest request) {
        if (request == null) {
            return "0.0.0.0";
        }

        String Xip = request.getHeader("X-Real-IP");
        String XFor = request.getHeader("X-Forwarded-For");

        String UNKNOWN_IP = "unknown";
        if (StringUtils.isNotEmpty(XFor) && !UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            //多次反向代理后会有多个ip值,第一个ip才是真实ip
            int index = XFor.indexOf(",");
            if (index != -1) {
                return XFor.substring(0, index);
            } else {
                return XFor;
            }
        }

        XFor = Xip;
        if (StringUtils.isNotEmpty(XFor) && !UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            return XFor;
        }

        if (StringUtils.isBlank(XFor) || UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            XFor = request.getHeader("Proxy-Client-IP");
        }
        if (StringUtils.isBlank(XFor) || UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            XFor = request.getHeader("WL-Proxy-Client-IP");
        }
        if (StringUtils.isBlank(XFor) || UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            XFor = request.getHeader("HTTP_CLIENT_IP");
        }
        if (StringUtils.isBlank(XFor) || UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            XFor = request.getHeader("HTTP_X_FORWARDED_FOR");
        }
        if (StringUtils.isBlank(XFor) || UNKNOWN_IP.equalsIgnoreCase(XFor)) {
            XFor = request.getRemoteAddr();
        }
        return XFor;
    }
}

被导出的实体:加入注解:@Excel(name = “id”,width = 20)
图片仅为示例
在这里插入图片描述

前端调用:换成自己的接口url的path,点击按钮,调方法,用axios get请求

downExcel(){
      console.log('操作=============导出文档-1')
       this.downloadRequest('/obj/project/exportExcel').then(data => {
        console.log(data)
      })
      console.log('操作=============导出文档-2')
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我先来一碗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值