当前位置: 首页 > news >正文

[springboot专栏]文件本地上传与提供访问服务

本章的核心内容是为大家介绍分布式文件系统,用于存储应用的图片、word、excel、pdf等文件。在开始介绍分布式文件系统之前,为大家介绍一下使用本机存储来存放文件资源。
二者的核心实现过程是一样的:

  • 上传文件,保存文件(本节是本地磁盘)
  • 返回文件HTTP访问服务路径给前端,进行上传之后的效果展示

一、复习

服务端接收上传的目的是提供文件的访问服务,那么对于SpringBoot而言,有哪些可以提供文件访问的静态资源目录呢?

  • classpath:/META-INF/resources/ ,
  • classpath:/static/ ,
  • classpath:/public/ ,
  • classpath:/resources/

这是之前的章节,我们为大家介绍的内容,从这里看出这里的静态资源都在classpath下。那么就出现问题:

  • 应用的文件资源不能和项目代码分开存储(你见过往github上传代码,还附带项目文件数据的么?)
  • 项目打包困难,当上传的文件越来越多,项目的打包jar越来越大。
  • 代码与文件数据不能分开存储,就意味着文件数据的备份将变得复杂

二、文件上传目录自定义配置

怎么解决上述问题?别忘记了spring boot 为我们提供了使用spring.resources.static-locations配置自定义静态文件的位置。

web:
  upload-path: D:/data/

spring:
  resources:
    static-locations: classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/,file:${web.upload-path}
  • 配置web.upload-path为与项目代码分离的静态资源路径,即:文件上传保存根路径
  • 配置spring.resources.static-locations,除了带上Spring Boot默认的静态资源路径之外,加上file:${web.upload-path}指向外部的文件资源上传路径。该路径下的静态资源可以直接对外提供HTTP访问服务。

三、文件上传的Controller实现

详情看代码注释

@RestController
public class FileUploadController {

  //绑定文件上传路径到uploadPath
  @Value("${web.upload-path}")
  private String uploadPath;

  SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd/");

  @PostMapping("/upload")
  public String upload(MultipartFile uploadFile,
                       HttpServletRequest request) throws IOException {

    // 在 uploadPath 文件夹中通过日期对上传的文件归类保存
    // 比如:/2019/06/06/cf13891e-4b95-4000-81eb-b6d70ae44930.png
    String format = sdf.format(new Date());
    File folder = new File(uploadPath + format);
    if (!folder.isDirectory()) {
      folder.mkdirs();
    }

    // 对上传的文件重命名,避免文件重名
    String oldName = uploadFile.getOriginalFilename();
    String newName = UUID.randomUUID().toString()
            + oldName.substring(oldName.lastIndexOf("."), oldName.length());


    // 文件保存
    uploadFile.transferTo(new File(folder, newName));

    // 返回上传文件的访问路径
    //https://localhost:8888/2020/10/18/a9a05df4-6615-4bb5-b859-a3f9bf4bfae0.jpg
    String filePath = request.getScheme() + "://" + request.getServerName()
            + ":" + request.getServerPort() + "/"   + format + newName;
    return filePath;
  }

}

四、写一个模拟的文件上传页面,进行测试

把该upload.html文件放到classpath:public目录下,对外提供访问。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="/upload" method="post" enctype="multipart/form-data">
    <input type="file" name="uploadFile" value="请选择上传文件">
    <input type="submit" value="保存">
</form>
</body>
</html>

访问测试、点击“选择文件”,之后保存
在这里插入图片描述

文件被保存到服务端的web.upload-path指定的资源目录下
在这里插入图片描述

浏览器端响应结果如下,返回一个文件HTTP访问路径:
在这里插入图片描述

使用该HTTP访问路径,在浏览器端访问效果如下。证明我们的文件已经成功上传到服务端,以后需要访问该图片就通过这个HTTP URL就可以了。 或者使用前端html的img标签即可回显已上传图片.
在这里插入图片描述
欢迎关注公众号:字母哥杂谈,赠送各种我写的专栏PDF成书版本,如:回复003赠送专栏《docker修炼之道》。 字母哥博客:zimug.com

相关文章:

  • 基于AI算法的数据库异常监测系统的设计与实现
  • 猿创征文|手把手玩转docker,从入门到精通
  • 【Rust日报】2022-08-31 RustDesk 跻身 Rust 开源项目 Top 10 第九名
  • 【项目】通讯录1(C语言)
  • 一年赚一百万的思路—别做大多数的傻瓜
  • Java基于JSP+Servlet的宠物养护网站
  • 【spring】一文读懂SpringIOC和AOP
  • 在Adult数据集上使用pandas进行独热编码,之后部署Logistic Reggresion模型
  • Dubbo分组聚合
  • 前端HTML5 +CSS3 3. HMTL基础 3 表单标签
  • 2022.9.1 SAP RFC
  • Dubbo初次使用(广播形式)
  • JSP汽车维修服务管理系统myeclipse开发SqlServer数据库bs框架java编程web网页结构
  • 【算法合集】学习算法第六天(贪心篇)
  • Nginx之正则表达式、location匹配简介及rewrite重写
  • Angular4 模板式表单用法以及验证
  • centos安装java运行环境jdk+tomcat
  • IndexedDB
  • js学习笔记
  • node入门
  • 分类模型——Logistics Regression
  • 欢迎参加第二届中国游戏开发者大会
  • 前端攻城师
  • 前端技术周刊 2018-12-10:前端自动化测试
  • 深度学习中的信息论知识详解
  • - 语言经验 - 《c++的高性能内存管理库tcmalloc和jemalloc》
  • 阿里云移动端播放器高级功能介绍
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • ​低代码平台的核心价值与优势
  • #经典论文 异质山坡的物理模型 2 有效导水率
  • (06)Hive——正则表达式
  • (145)光线追踪距离场柔和阴影
  • (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
  • (C语言)字符分类函数
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (附源码)springboot电竞专题网站 毕业设计 641314
  • (附源码)ssm失物招领系统 毕业设计 182317
  • (三) diretfbrc详解
  • (转)人的集合论——移山之道
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • ./configure、make、make install 命令
  • .[backups@airmail.cc].faust勒索病毒的最新威胁:如何恢复您的数据?
  • .chm格式文件如何阅读
  • .net MVC中使用angularJs刷新页面数据列表
  • .net web项目 调用webService
  • .NET开发者必备的11款免费工具
  • .NET设计模式(8):适配器模式(Adapter Pattern)
  • .net专家(高海东的专栏)
  • ?.的用法
  • @Autowired多个相同类型bean装配问题
  • @Controller和@RestController的区别?
  • [AR]Vumark(下一代条形码)
  • [IT生活推荐]大家一起来玩游戏喽,来的都进!