SpringBoot实现图片上传及本地访问
作者:_多拉不懂A梦
在SpringBoot项目中,处理静态文件访问尤其是实时更新的文件如商品图片,可通过配置WebMvcConfig将本地文件映射到URL路径上,以解决重启项目才能访问文件的问题,本文详解如何保存和访问这些文件,帮助开发者优化项目文件管理
项目需求
最近做软件架构平台的课程实验时遇到这样的一个问题。需求是要修改商品的图片,完成图片的上传,这本身并不难,使用form-data的格式进行交互就能完成。但是上传后无法立马访问到才是最头疼的问题。
一开始选择是将图片存到static目录下面,当作静态文件处理,但是后面发现,只有重启项目后,静态文件加载到target中才能访问到。
找了很多解决办法,最终找到了合适的方案。
springboot静态文件讲解
springboot的静态文件根据需求我们可以分成两种
恒不变的项目静态文件static:
- 这种类型的文件是项目建立初就不会变动的文件,典型的有各种各样的UI库,bootstrap,jquery,还有项目的图标等等。
- 这些文件最终会被加载到项目的target目录下,作为类似项目的依赖包持续使用,差不多和maven依赖包一样。
target目录下的文件不需要进行任何配置尽可以通过域名加目录直接访问到。如localhost:8080/echarts/echarts.min.js
持续上传更新的文件file:
- 这一类文件是保存在系统服务端的数据文件,会不断的收到用户和管理员的CRUD操作处理,典型的有系统文档,商品图片等等。
- 这些文件仅保存在服务端,但是不会进入项目目录下,更不会加载到target中。
上传文件
根据上面的描述,我们很清楚我们需要解决的就是如何存储持续上传更新的文件,以及如何才能访问的到。
写一个上传文图片的接口,并将图片保存到本地的目录项
public class Constant { public static final String ITEM_PICTURE_PATH = "D:\\Tools\\"; }
@PostMapping("/importPicture") public MsgEntity importPicture(@RequestParam("file") MultipartFile file, @RequestParam("id") String id) throws FileNotFoundException { //获得文件的后缀 String filename = UUID.randomUUID() + Objects.requireNonNull(file.getOriginalFilename()).substring(file.getOriginalFilename().lastIndexOf(".")); //获取文件存储路径 File filepath = new File(Constant.ITEM_PICTURE_PATH + filename); String url = String.valueOf(filepath); try { //存文件 file.transferTo(filepath); } catch (IOException e) { e.printStackTrace(); } itemService.setPictureUrl("http://localhost:8080/temp-image/" + filename, id); return new MsgEntity("SUCCESS", "200", url); }
访问文件
上传文件已经完成了,那么如何访问到存储在本地服务器的文件呢?
其实SpringBoot已经很好的为我们解决了这个问题,我们只需要加上一点配置,就能将本地文件映射到url路径上。
在properties中加上自定义配置
# 配置上传图片的路径和访问图片图片的路径 upload.file.location=file:D:/Tools/ upload.file.path =/temp-image/**
编写WebMvcConfig的配置类
@Configuration public class MyWebAppConfigurer implements WebMvcConfigurer { @Value("${upload.file.location}") private String fileLocation; @Value("${upload.file.path}") private String filePath; @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { //注册配置类,使用addResourceHandlers方法,将本地路径fileLocation映射到filePath路由上。 registry.addResourceHandler(filePath).addResourceLocations(fileLocation); WebMvcConfigurer.super.addResourceHandlers(registry); } }
这样就可以在浏览器上 访问了
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。