springMVC实现excel文件上传和下载

本文详细介绍了如何使用SpringMVC实现在Web应用中进行Excel文件的上传和下载。首先,在pom.xml中引入了必备的jar包,如文件上传解析器和处理Excel的库。接着,配置了spring-web.xml以支持文件上传。然后,分别展示了单个、多个和带参数的Excel文件上传的前端Thymeleaf代码及其对应的后端处理逻辑。最后,讲解了如何实现Excel文件的下载,包括直接下载和创建新的Excel文件供用户下载。
摘要由CSDN通过智能技术生成

springMVC实现文件上传和下载


pom.xml

关键jar包如下:

    <!-- 文件上传 -->
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.3.3</version>
    </dependency>
    <!-- apache poi -->
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.17</version>
    </dependency>

其中, commons-fileupload 适用于文件上传和下载的jar包, poi-ooxml 是支持操作excel文件的jar包.

spring-web.xml

需要在spring的配置文件中配置上传文件的解析器.

    <!-- 4: 文件上传解析器 -->
    <bean id="multipartResolver"
        class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <!-- 设定默认编码 -->
        <property name="defaultEncoding" value="UTF-8"/>
        <!-- 设定文件上传的最大值为5MB, 5*1024*1024 = 5242880 -->
        <property name="maxUploadSize" value="5242880"/>
        <!-- 设定文件上传时写入内存的最大值, 如果小于这个参数不会生成临时文件, 默认为10240 -->
        <property name="maxInMemorySize" value="40960"/>
        <!-- 上传文件的临时路径 -->
        <property name="uploadTempDir" value="upload/temp/"/>
        <!-- 延迟文件解析 -->
        <property name="resolveLazily" value="true" />
    </bean>

单个excel文件上传

前端代码(使用thymeleaf模板引擎)

<div>
    <p>单个excel文件上传</p>
    <form th:action="@{/excel/import}" method="post" enctype="multipart/form-data">
        <input type="file" name="excelFile"/>
        <input type="submit" value="导入单个excel文件"/>
    </form>
</div>

后端代码

这里使用了 POIUtil 工具类解析excel文件, 传送门

    /**
     * * 从web页面导入单个excel文件
     *
     * @param excelFile 上传的excel文件
     * @param request   Request对象
     * @return 内容
     * @throws IOException
     */
    @PostMapping("/excel/import")
    @ResponseBody
    
  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值