鸿蒙分布式文件系统,java中什么是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) {

// 在 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());

try {

// 文件保存

uploadFile.transferTo(new File(folder, newName));

// 返回上传文件的访问路径

String filePath = request.getScheme() + "://" + request.getServerName()

+ ":" + request.getServerPort() + format + newName;

return filePath;

} catch (IOException e) {

throw new CustomException(CustomExceptionType.SYSTEM_ERROR);

}

}

}

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

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

Title

访问测试、点击“选择文件”,之后保存

8cd9593fc49fe4440d8108c2f16bfa81.png

文件被保存到服务端的web.upload-path指定的资源目录下

82336fccd9a3bbac90a73c31701ff21a.png

浏览器端响应结果如下,返回一个文件HTTP访问路径:

cc601980ccdcd19a63b13d0b01adefc6.png

使用该HTTP访问路径,在浏览器端访问效果如下。证明我们的文件已经成功上传到服务端,以后需要访问该图片就通过这个HTTP URL就可以了。

76cb039c446adfef6c514eca485a0a98.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值