• SpringBoot 优雅地实现文件的上传和下载


    1.效果演示

    2.技术栈

    • maven
    • springboot
    • mybatis-plus
    • mysql
    • thymeleaf
    • bootstrap

    3.数据库表

    1. CREATE TABLE `t_upload_file` (
    2. `id` bigint(11) NOT NULL AUTO_INCREMENT,
    3. `old_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
    4. `new_Name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
    5. `url_path` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
    6. `size` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
    7. `file_type` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
    8. `created_date` datetime DEFAULT NULL,
    9. PRIMARY KEY (`id`)
    10. ) ENGINE=InnoDB AUTO_INCREMENT=40 DEFAULT CHARSET=utf8;
    11. 复制代码

    4.创建 springboot 项目

    5.引入依赖

    这里我们主要引入以下依赖:

    • web
    • mybatis-plus
    • mysql 驱动
    • thymeleaf
    • commons-fileupload
    • lombok

    commons-fileupload 是一个上传文件的组件,该组件封装了一些上传文件的方法。

    1. <!-- web-->
    2. <dependency>
    3. <groupId>org.springframework.boot</groupId>
    4. <artifactId>spring-boot-starter-web</artifactId>
    5. </dependency>
    6. <!-- mybatis-plus 依赖-->
    7. <dependency>
    8. <groupId>com.baomidou</groupId>
    9. <artifactId>mybatis-plus-boot-starter</artifactId>
    10. <version>3.4.0</version>
    11. </dependency>
    12. <!-- mysql驱动 -->
    13. <dependency>
    14. <groupId>mysql</groupId>
    15. <artifactId>mysql-connector-java</artifactId>
    16. <scope>runtime</scope>
    17. </dependency>
    18. <!--thymeleaf-->
    19. <dependency>
    20. <groupId>org.springframework.boot</groupId>
    21. <artifactId>spring-boot-starter-thymeleaf</artifactId>
    22. </dependency>
    23. <!-- lombok -->
    24. <dependency>
    25. <groupId>org.projectlombok</groupId>
    26. <artifactId>lombok</artifactId>
    27. <optional>true</optional>
    28. </dependency>
    29. <!-- commons-fileupload -->
    30. <dependency>
    31. <groupId>commons-fileupload</groupId>
    32. <artifactId>commons-fileupload</artifactId>
    33. <version>1.4</version>
    34. </dependency>
    35. 复制代码

    6.修改配置文件

    这里主要包含数据源、thymeleaf、mybatis-plus 三个模块的配置。

    7.代码生成

    这里使用 mybatis-plus 的代码生成工具自动生成 controller、entity、service、mapper,极大地提高代码开发效率。

    记得添加以下依赖:

    1. <!-- 代码生成器 -->
    2. <dependency>
    3. <groupId>com.baomidou</groupId>
    4. <artifactId>mybatis-plus-generator</artifactId>
    5. <version>3.5.1</version>
    6. </dependency>
    7. <dependency>
    8. <groupId>org.freemarker</groupId>
    9. <artifactId>freemarker</artifactId>
    10. </dependency>
    11. 复制代码

    输入表名然后运行该程序:

    8.前端

    前端主要使用了 thymeleaf 和 bootstrap。Thymeleaf 是一种模板引擎技术,bootstrap 是 Twitter 推出的前端开发框架。

    新建 index.html 文件,分别引入 bootstrap 的 css 和 Thymeleaf 的命名空间。

    9.文件列表功能

    后端:

    查询列表数据,封装到 model 里面,然后跳转到列表页面。

    前端:

    列表页面使用 Thymeleaf 常用的标签:

    10.文件上传

    前端表单发起 post 请求,切记 enctype 格式是 multipart/form-data。

    1. <form method="post" enctype="multipart/form-data" th:action="@{/file/upload}">
    2. <input type="file" name="multipartFile">
    3. <input type="submit" style="margin-top:20px" value="点击上传" class="btn btn-primary btn-sm"/>
    4. </form>
    5. 复制代码

    后端用 MultipartFile 类型的对象接收文件,然后将文件拷贝到固定格式文件夹下:

    1. /项目根路径/static/files/20xx-xx-xx/xxxx.jpg
    2. 复制代码

    其中上传文件的核心代码:

    1. multipartFile.transferTo(new File(finalFile, newName));
    2. 复制代码

    我们发现 transferTo 方法核心还是 IO 的读写操作:

    11.文件下载

    1.先根据文件 id 查询文件信息,然后根据文件所在路径和文件名获取文件输入流。

    2.设置响应头的扩展头、下载文件的名称。

    3.获取文件输出流

    4.关闭文件输入输出流

    12.删除文件

    1.先根据文件 id 查询文件信息,然后根据文件所在路径和文件名获取 file 对象。

    2.如果 file 对象存在就删除该文件。

    3.删除数据库中该文件信息。

    13.项目完整代码

    1. 链接:https://pan.baidu.com/s/1LODyH8TcVxnKqYprPoOo7g?pwd=1234
    2. 提取码:1234


     

  • 相关阅读:
    SpringBoot整合sql数据源
    PCL 刚性物体的位姿估计 PFH、FPFH、VFH、PPF
    进程间通信(IPC)-管道、消息队列、信号量、共享存储、socket
    【Spark 实战系列】Spark 使用 BulkLoad 同步数据到 hbase 排序优化
    react函数式组件ref形式子向父传参
    2022-6-2
    xamarin使用Rg.Plugins.Popup.Pages报Specified cast is not valid
    C++ if 语句
    大型语言模型,第 1 部分:BERT
    解密网络通信的关键技术(上):DNS、ARP、DHCP和NAT,你了解多少?
  • 原文地址:https://blog.csdn.net/java1527/article/details/127207498