项目数据导出成PDF文件

项目数据导出成PDF文件

模板准备:

数据格式模板如:abc.xlsx

页面处理:
绑定事件:
<el-button @click="exportPDF">导出Excel</el-button>运营数据统计
发送请求:

不能用ajax,因为接受的是文件输出流,ajax接受的是json

methods:{exportPDF(){        
window.location.href = '/report/exportBusinessReport4PDF.do';
}}
后端代码实现:
1.查询出数据
2.获取并编译模板
3.填充数据
4.使用输出流进行表格下载
    @RequestMapping("/exportBusinessReport4PDF")
    public void exportBusinessReport4PDF(HttpServletRequest request,HttpServletResponse response) throws Exception {
        //1.获取数据
        Map<String, Object> result = reportService.getBusinessReportData();
        List<Map> hotSetmeal = (List<Map>)result.get("hotSetmeal");
        //2.获取模板文件路径
        String jrmxlPath=request.getSession().getServletContext().getRealPath("/template")+File.separator
                + "health_business3.jrxml";
        String jasperPath=request.getSession().getServletContext().getRealPath("/template")+File.separator
                + "health_business3.jasper";
        // 编译模板
        JasperCompileManager.compileReportToFile(jrmxlPath,jasperPath);
        // 3.填充数据
        JasperPrint jasperPrint = JasperFillManager.fillReport(jasperPath, result, new JRBeanCollectionDataSource(hotSetmeal));
        //4.设置响应信息
        ServletOutputStream out = response.getOutputStream();
        response.setContentType("application/pdf");
        response.setHeader("content-disposition","attachment;filename=report.pdf");
        // 输出文件
        JasperExportManager.exportReportToPdfStream(jasperPrint,out);
    }

业务层,持久层查询语句:

略…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值