千家信息网

Springboot怎么实现前后端分离excel下载

发表于:2024-12-01 作者:千家信息网编辑
千家信息网最后更新 2024年12月01日,本篇内容介绍了"Springboot怎么实现前后端分离excel下载"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,
千家信息网最后更新 2024年12月01日Springboot怎么实现前后端分离excel下载

本篇内容介绍了"Springboot怎么实现前后端分离excel下载"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

Springboot前后端分离excel下载

现在公司的技术栈是springboot作为后端,前端是vue, 现在要做excel的导出功能, 之前没做过,写一下记录下.

springboot版本是2.0.6 poi 3.14 ,jdk1.8

类上面的注解是: @RestController

/**     * 导出excel     *      */    @GetMapping("export")    public void exportExcel() {        XSSFWorkbook workbook = placeStatService.exportExcel();        // 设置生成的Excel的文件名,并以中文进行编码        String fileName = null;        try {            fileName = URLEncoder.encode("房间预约使用统计表" + ".xlsx", "utf-8").replaceAll("\\+", "%20");        } catch (UnsupportedEncodingException e) {            e.printStackTrace();        }        response.setCharacterEncoding("UTF-8");        response.setHeader("Content-type", "application/vnd.ms-excel");        response.setHeader("Content-Disposition", "attachment;filename=" + fileName);        // 响应类型,编码        response.setContentType("application/octet-stream;charset=UTF-8");        try {            // 形成输出流            OutputStream osOut = response.getOutputStream();            // 将指定的字节写入此输出流            workbook.write(osOut);            // 刷新此输出流并强制将所有缓冲的输出字节被写出            osOut.flush();            // 关闭流            osOut.close();            workbook.close();        } catch (IOException e) {            e.printStackTrace();        }    }
@Override    public XSSFWorkbook exportExcel) {        List roomOrdersList = getRoomOrderList();        XSSFWorkbook data = ExcelUtil.setExcelData(roomOrdersList);        return data;    }
package com.util; import com.curefun.place.model.RoomOrderDetailModel;import org.apache.poi.ss.usermodel.HorizontalAlignment;import org.apache.poi.ss.usermodel.VerticalAlignment;import org.apache.poi.xssf.usermodel.XSSFCell;import org.apache.poi.xssf.usermodel.XSSFCellStyle;import org.apache.poi.xssf.usermodel.XSSFRow;import org.apache.poi.xssf.usermodel.XSSFSheet;import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.text.SimpleDateFormat;import java.util.Date;import java.util.List; /** * @author excel 工具类. 导出功能 */public class ExcelUtil {      /**     * 数据导出, 获取一个excel对象     *     * @param     */    public static XSSFWorkbook setExcelData(List orderDetailModels) {        //创建一个book,对应一个Excel文件        XSSFWorkbook workbook = new XSSFWorkbook();        //在book中添加一个sheet,对应Excel文件中的sheet        XSSFSheet sheet = workbook.createSheet("教室预约使用记录");        //设置六列的宽度        sheet.setColumnWidth(0, 4000);        sheet.setColumnWidth(1, 3000);        sheet.setColumnWidth(2, 3800);        sheet.setColumnWidth(3, 2800);        sheet.setColumnWidth(4, 3200);        sheet.setColumnWidth(5, 3600);        sheet.setColumnWidth(6, 2850);         //居中的样式        XSSFCellStyle centerStyle = getCenterStyle(workbook);         // 第三步,在sheet中添加表头第0行        XSSFRow row0 = sheet.createRow(0);        setFirstRow(centerStyle, row0);         int rowNum = 1;        for (RoomOrderDetailModel model : orderDetailModels) {            XSSFRow row = sheet.createRow(rowNum);            row.createCell(0).setCellValue(rowNum);            rowNum++;            row.createCell(1).setCellValue(model.getBuildingName());            row.createCell(2).setCellValue(model.getRoomNo());            row.createCell(3).setCellValue(model.getRoomName());            row.createCell(4).setCellValue(model.getEventType());            row.createCell(5).setCellValue(model.getEventName());            row.createCell(6).setCellValue(model.getUserRealName());        }        return workbook;    }       /**     * 获取居中的样式.     *     * @param workbook     * @return     */    private static XSSFCellStyle getCenterStyle(XSSFWorkbook workbook) {        XSSFCellStyle cellStyle = workbook.createCellStyle();        //设置水平对齐的样式为居中对齐;        cellStyle.setAlignment(HorizontalAlignment.CENTER);        //垂直居中        cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);        return cellStyle;    }      /**     * 设置第一行的表头     *     * @param centerStyle     * @param row     */    private static void setFirstRow(XSSFCellStyle centerStyle, XSSFRow row) {        XSSFCell cell0 = row.createCell(0);        cell0.setCellValue("序号");        cell0.setCellStyle(centerStyle);        XSSFCell cell1 = row.createCell(1);        cell1.setCellValue("楼栋信息");        cell1.setCellStyle(centerStyle);        XSSFCell cell2 = row.createCell(2);        cell2.setCellValue("房号");        cell2.setCellStyle(centerStyle);        XSSFCell cell3 = row.createCell(3);        cell3.setCellValue("房间名称");        cell3.setCellStyle(centerStyle);        XSSFCell cell4 = row.createCell(4);        cell4.setCellValue("活动类型");        cell4.setCellStyle(centerStyle);        XSSFCell cell5 = row.createCell(5);        cell5.setCellValue("活动名称");        cell5.setCellStyle(centerStyle);        XSSFCell cell6 = row.createCell(6);        cell6.setCellValue("使用人");        cell6.setCellStyle(centerStyle); /**其实完全使用这种方式, 会更加的简单,便于修改List title = Stream.of("序号", "专业", "班级", "课程名称", "课程内容", "授课教师", "授课时长", "授课时间", "学分", "授课房间")                .collect(Collectors.toList());        for (int i = 0; i < title.size(); i++) {            XSSFCell cell = row.createCell(i);            cell.setCellValue(title.get(i));            cell.setCellStyle(centerStyle);        }*/    } }

其实使用很简单,就是excel的文件名需要进行编码,这个需要注意,其他没啥的了.

前后端分离Excle下载乱码问题

前端:vue+elementUI

后端:springCloud

前端请求方式 : ajax请求

this.$.ajax({                url :this.url + "/",                type : 'post',                data : formData,                contentType: false,                processData: false,                xhrFields: {withCredentials: true, responseType:'arraybuffer'},                headers : {'Access-Control-Allow-Origin': '*', "Authorization": this.ajaxRequest.getToken()},                success: function (res, textStatus, request) {                    var downloadFile = document.createElement('a');                    let blob = new Blob([res], {type : "application/vnd.ms-excel;charset=UTF-8"});                    downloadFile.href = window.URL.createObjectURL(blob);                    console.log(request.getResponseHeader('Content-disposition'));                    downloadFile.download =                     decodeURI(request.getResponseHeader('Content-disposition').split('filename=')[1] );                    downloadFile.click();                    window.URL.revokeObjectURL(downloadFile.href);                },                error : function (res) {                  console.log(res)                }        })

后端处理:导出文件处理

// 输出Excel文件OutputStream out = null;out = response.getOutputStream();response.reset();response.setCharacterEncoding("UTF-8");response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF8"));response.setContentType("application/vnd.ms-excel; charset=utf-8");// 输出Excel内容,生成Excel文件wb.write(out);

"Springboot怎么实现前后端分离excel下载"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

文件 输出 内容 前端 名称 房间 样式 编码 功能 字节 序号 文件名 方式 更多 知识 类型 表头 课程 UTF-8 处理 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 短距离无线通信网络安全综述 云上服务器配置文件地址怎么配 泰州营销软件开发定做价格 数据库支持虚拟化部署 落实网络安全加强信息化建设 学习java用什么数据库 服务器怎么匹配地区人的 网络安全包含四层含义 一个数据库中有多少张表如何知道 联想ibm服务器调品质 软件开发结构化生命周期 厦门公司管理财务软件开发 常见软件开发平台 广东省数据库期末考试题目 宝鸡第六届网络安全周 安宁管理软件开发 网络安全的知识内容有些什么 全世界英雄联盟有多少个服务器 连接数据库失败请检查 敢达争锋对决台服连接不上服务器 南昌大学网络安全大赛 怎么删除数据库归档日志文件 软件产品与软件开发服务 计算网络技术(G5)学费多少 平顶山三门峡直销软件开发价格 郑州仁峰软件开发有限公司杨高峰 从网络工程师变成软件开发 mc无死亡不掉落服务器推荐 护苗网络安全班会教案博客 深圳必过网络技术公司
0