poi封装及导入下载服务资源[根据类名称资源下载方式]

2023-10-24 08:32

本文主要是介绍poi封装及导入下载服务资源[根据类名称资源下载方式],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里直接贴代码了

导入Excel

前端上传

<from enctype="multipart/from-data" method="post" action="/import">

<input type="file" name="file"/>

<input type="submit" value="上传"/>

</from>

上传文件的参数名为file

后端接收

@RequestMapping("/import") public void importexcle(@ExcelRequestBody(titleRows = 2, headRows = 1, requireClass = City.class) List<City>vo) throws Exception {for (int i = 0; i < vo.size(); i++) {System.out.println(vo.get(i));

//做相应的数据处理

    } }

在SpringMVC的方法内使用@ExcelRequestBody注解,titleRow为标题的行数,headRows为标题栏的行数,通常为1。requireClass为 Excel类数据需要转换成的对象。

看一下对象的示例:

@ExcelTarget("ItsmSystemUserBean")
@Table(name = "itsm_sys_user")
public class ItsmSystemUserBean {@Id
    @GeneratedValue(generator = "JDBC")private String id;

    /**
     * 姓名
     */
    @NotEmpty
    @Excel(name = "姓名 *", orderNum = "2", width = 20,needMerge = false)private String userName;

    /**
     * 登录id
     */
    @NotEmpty
    @Excel(name = "登录id *", orderNum = "3", width = 18,needMerge = false)private String loginName;


导入导出Excel的对象上使用@ExcelTarget注解,并指定一个唯一的id。
在需要进行处理的字段上使用@Excel注解,name为Excel表格的head,orderNum为字段的顺序,不可重复!
needMerge用于合并,通常不需要使用。更详细的用法可参考:http://www.afterturn.cn/doc/easypoi.html
3、导出Excel
在需要导出Excel的方法上添加@ExportExcel(fileName = "测试")注解。
fileName用于指定下载的文件名称。excelType可用于指定Excel版本,默认为03格式。
示例:

ExportParams的title为标题,secondTitle为二级标题,sheetName为sheet的名称。
使用ExcelExportUtil.exportExcel方法导出数据到指定对象,最后写入response。此行代码后不可以有任何代码!导出方法的返回值为void
/**
 * 导出Excel,这里没有使用向模版填充数据
 * <p>
 * <br>【请求地址】/itsm/system/sso/user/exportExcelUser
 *
 * @param userIds 用户id 字符串
 * @throws IOException
 */
@RequestMapping("/exportExcelUser")
@ExportExcel(fileName = "人员管理基本信息")
public void exportExcelUser(HttpServletResponse response, @RequestParam(name = "userIds") List<String> userIds) throws IOException {logger.info(this.getClass().getName());
    List<ItsmSystemUserBean> userBeanList = this.userService.queryUserBeanById(userIds);
    ExportParams params = new ExportParams("人员管理基本信息", "*为必填", "人员基本信息");
    ExcelExportUtil.exportExcel(params, ItsmSystemUserBean.class, userBeanList).write(response.getOutputStream());
}

=========================第二篇=============================
下载服务资源
1.controlle方法体
/**
 * 下载导入模版
 * <br>【请求地址】/itsm/system/sso/user/downloadExcelUser
 *
 * @param
 * @throws IOException
 */
@RequestMapping("/downloadExcelUser")
public void downloadExcelUser(HttpServletRequest request, HttpServletResponse response) throws Exception {//multipart/form-data  设置文件ContentType类型,这样设置,会自动判断下载文件类型
    ResponseUtill.download(request, response, "人员管理基本信息.xls", "multipart/form-data");
}
2.引用工具类
import org.apache.commons.lang3.StringUtils;
import org.apache.tomcat.util.http.fileupload.IOUtils;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.net.URLEncoder;

/**
     * 文件下载.
     *
     * @param request
     * @param response
     * @param name 文件名.
     * @param contentType 文件类型.
     */
    public static void download(HttpServletRequest request,
                                HttpServletResponse response,
                                String name,
                                String contentType) throws Exception {// 最终返回给浏览器的文件名.
        String finalFileName = null;

        final String userAgent = request.getHeader("USER-AGENT");
        // IE浏览器.
        if(StringUtils.contains(userAgent, "MSIE")) {finalFileName = URLEncoder.encode(name,"UTF8");
        }// Google,火狐浏览器
        else if(StringUtils.contains(userAgent, "Mozilla")) {finalFileName = new String(name.getBytes(), "ISO8859-1");
        }// 其他浏览器.
        else{finalFileName = URLEncoder.encode(name,"UTF8");
        }// 告诉浏览器用什么软件可以打开此文件.
        response.setHeader("content-Type", contentType);
        // 下载文件的默认名称.
        response.setHeader("Content-Disposition", "attachment;filename=" + finalFileName);
        // 编码.
        response.setCharacterEncoding("UTF-8");

        Resource resource = new ClassPathResource(name);
        IOUtils.copy(resource.getInputStream(), response.getOutputStream());
        response.flushBuffer();
    }}

这篇关于poi封装及导入下载服务资源[根据类名称资源下载方式]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/273970

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

JavaSE——封装、继承和多态

1. 封装 1.1 概念      面向对象程序三大特性:封装、继承、多态 。而类和对象阶段,主要研究的就是封装特性。何为封装呢?简单来说就是套壳屏蔽细节 。     比如:对于电脑这样一个复杂的设备,提供给用户的就只是:开关机、通过键盘输入,显示器, USB 插孔等,让用户来和计算机进行交互,完成日常事务。但实际上:电脑真正工作的却是CPU 、显卡、内存等一些硬件元件。

前端form表单+ifarme方式实现大文件下载

// main.jsimport Vue from 'vue';import App from './App.vue';import { downloadTokenFile } from '@/path/to/your/function'; // 替换为您的函数路径// 将 downloadTokenFile 添加到 Vue 原型上Vue.prototype.$downloadTokenF

基于SpringBoot的宠物服务系统+uniapp小程序+LW参考示例

系列文章目录 1.基于SSM的洗衣房管理系统+原生微信小程序+LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统+LW参考示例 3.基于SpringBoot+Vue的企业人事管理系统+LW参考示例 4.基于SSM的高校实验室管理系统+LW参考示例 5.基于SpringBoot的二手数码回收系统+原生微信小程序+LW参考示例 6.基于SSM的民宿预订管理系统+LW参考示例 7.基于

哈希表的封装和位图

文章目录 2 封装2.1 基础框架2.2 迭代器(1)2.3 迭代器(2) 3. 位图3.1 问题引入3.2 左移和右移?3.3 位图的实现3.4 位图的题目3.5 位图的应用 2 封装 2.1 基础框架 文章 有了前面map和set封装的经验,容易写出下面的代码 // UnorderedSet.h#pragma once#include "HashTable.h"

49个权威的网上学习资源网站

艺术与音乐 Dave Conservatoire — 一个完全免费的音乐学习网站,口号是“让每一个人都可以接受世界级的音乐教育”,有视频,有练习。 Drawspace — 如果你想学习绘画,或者提高自己的绘画技能,就来Drawspace吧。 Justin Guitar — 超过800节免费的吉他课程,有自己的app,还有电子书、DVD等实用内容。 数学,数据科学与工程 Codecad