前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >这才是文件上传和下载的正确方式!

这才是文件上传和下载的正确方式!

作者头像
知否技术
发布2022-12-22 19:29:44
6790
发布2022-12-22 19:29:44
举报
文章被收录于专栏:eclipse编程eclipse编程

1.效果演示

2.技术栈

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

3.数据库表

代码语言:javascript
复制
CREATE TABLE `t_upload_file` (
  `id` bigint(11) NOT NULL AUTO_INCREMENT,
  `old_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `new_Name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `url_path` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `size` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `file_type` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `created_date` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=40 DEFAULT CHARSET=utf8;

4.创建 springboot 项目

5.引入依赖

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

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

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

代码语言:javascript
复制
<!-- web-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- mybatis-plus 依赖-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.0</version>
</dependency>
<!-- mysql驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>
<!--thymeleaf-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<!-- lombok -->
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
<!-- commons-fileupload -->
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.4</version>
</dependency>

6.修改配置文件

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

7.代码生成

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

记得添加以下依赖:

代码语言:javascript
复制
<!-- 代码生成器 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.1</version>
</dependency>
<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
</dependency>

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

8.前端

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

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

9.文件列表功能

后端:

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

前端:

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

10.文件上传

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

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

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

代码语言:javascript
复制
/项目根路径/static/files/20xx-xx-xx/xxxx.jpg

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

代码语言:javascript
复制
multipartFile.transferTo(new File(finalFile, newName));

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

11.文件下载

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

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

3.获取文件输出流。

4.关闭文件输入输出流。

12.删除文件

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

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

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

13.项目完整代码

代码语言:javascript
复制
链接:https://pan.baidu.com/s/1LODyH8TcVxnKqYprPoOo7g?pwd=1234 
提取码:1234

-END-

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-10-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 知否技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.效果演示
  • 2.技术栈
  • 3.数据库表
  • 4.创建 springboot 项目
  • 5.引入依赖
  • 6.修改配置文件
  • 7.代码生成
  • 8.前端
  • 9.文件列表功能
  • 10.文件上传
  • 11.文件下载
  • 12.删除文件
  • 13.项目完整代码
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档