java设置可供下载的excel模板文件

controller

java 复制代码
@GetMapping("/download/excel")  
@Operation(summary = "下载技术引入Excel模板")  
public void downloadTemplateExcel(HttpServletResponse response) {  
    technologyService.getTechnologyExcelModel(response);  
}

service

java 复制代码
public void getTechnologyExcelModel(HttpServletResponse response) {  
    List<TechnologyImportExcelDto> technologyImportExcelDtoList = getTechnologyImportExcelVOList();  
    File file;  
    try {  
        //使用临时文件  
        file = File.createTempFile("开源技术导入模板", ".xlsx");  
        FileOutputStream fileOutputStream = new FileOutputStream(file);  
        ExportParams params = new ExportParams("表格标题", "Sheet1", ExcelType.XSSF);  
        String tipsMessage = "开源技术导入需遵循以下规则:xxx";  
        params.setTitle(tipsMessage);  
  
        Workbook workbook = ExcelExportUtil.exportExcel(params, TechnologyImportExcelDto.class, technologyImportExcelDtoList);  
  
        // 获取Sheet对象  
        Sheet sheet = workbook.getSheetAt(0); // 只有一个Sheet  
  
        // 设置标题行样式  
        Row titleRow = sheet.getRow(0); // 标题在第一行  
  
        CellStyle titleStyle = workbook.createCellStyle();  
        titleStyle.setAlignment(HorizontalAlignment.LEFT); // 设置水平对齐方式为左对齐  
        titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); // 设置垂直对齐方式为居中  
        titleStyle.setWrapText(true); // 设置文本自动换行  
  
        // 设置边框  
        titleStyle.setBorderBottom(BorderStyle.THIN);  
        titleStyle.setBorderTop(BorderStyle.THIN);  
        titleStyle.setBorderLeft(BorderStyle.THIN);  
        titleStyle.setBorderRight(BorderStyle.THIN);  
  
        // 设置标题行每个单元格的样式  
        for (Cell cell : titleRow) {  
            cell.setCellStyle(titleStyle);  
        }  
  
        // 设置行高  
        titleRow.setHeightInPoints(titleRow.getHeightInPoints() * 4); // 设置为五行字的高度  
  
        // 设置字体加粗  
        Font font = workbook.createFont();  
        font.setBold(true);  
        titleStyle.setFont(font);  
  
        workbook.write(fileOutputStream);  
        fileOutputStream.close();  
        workbook.close();  
    } catch (IOException e) {  
        throw new RuntimeException(e);  
    }  
    //下载,读取文件流并将其添加到response的输出流中,同时设置响应的Header字段  
    try (InputStream inputStream = new FileInputStream(file);  
         //获取response的输出流对象  
         OutputStream outputStream = response.getOutputStream()) {  
        response.setContentType("application/octet-stream");  
        response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(file.getName(), StandardCharsets.UTF_8));  
        response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");  
        IOUtils.copy(inputStream, outputStream);  
        outputStream.flush();  
    } catch (Exception e) {  
        throw new RuntimeException();  
    } finally {  
        //清除文件  
        file.delete();  
    }  
}
java 复制代码
@NotNull  
private static List<TechnologyImportExcelDto> getTechnologyImportExcelVOList() {  
    List<TechnologyImportExcelDto> technologyImportExcelDtoList = new ArrayList<>();  
    TechnologyImportExcelDto technologyImportExcelDto = new TechnologyImportExcelDto(  
            "系统软件/固件",  
            "模板", 
            "x",  
            "1.0.0",  
            "GPL-2.0",  
            "http://xx.com",  
            "5",  
            "2023-03-15 14:17:02",  
            "http://download.com",  
            "描述内容");  
    technologyImportExcelDtoList.add(technologyImportExcelDto);  
    return technologyImportExcelDtoList;  
}
相关推荐
indexsunny3 小时前
互联网大厂Java求职面试实战:Spring Boot微服务与Redis缓存场景解析
java·spring boot·redis·缓存·微服务·消息队列·电商
无心水3 小时前
【分布式利器:腾讯TSF】7、TSF高级部署策略全解析:蓝绿/灰度发布落地+Jenkins CI/CD集成(Java微服务实战)
java·人工智能·分布式·ci/cd·微服务·jenkins·腾讯tsf
28岁青春痘老男孩8 小时前
JDK8+SpringBoot2.x 升级 JDK 17 + Spring Boot 3.x
java·spring boot
方璧8 小时前
限流的算法
java·开发语言
元Y亨H8 小时前
Nacos - 服务注册
java·微服务
曲莫终8 小时前
Java VarHandle全面详解:从入门到精通
java·开发语言
一心赚狗粮的宇叔9 小时前
中级软件开发工程师2025年度总结
java·大数据·oracle·c#
奋进的芋圆9 小时前
DataSyncManager 详解与 Spring Boot 迁移指南
java·spring boot·后端
计算机程序设计小李同学9 小时前
个人数据管理系统
java·vue.js·spring boot·后端·web安全
小途软件10 小时前
用于机器人电池电量预测的Sarsa强化学习混合集成方法
java·人工智能·pytorch·python·深度学习·语言模型