1、SpringBoot 项目将文件图片资源上传到本地静态资源文件夹下(指定文件夹下)

最终效果:
前端浏览本地文件,点击上传至本地resources/static/images/imgWall下
在这里插入图片描述

2、实现流程

1.构造前端页面的表单,需要注意的是< form >标签的属性设置enctype=“multipart/form-data”,以及提交方式设置为post

<form action="#" th:action="@{/admin/upload}" method="post" enctype="multipart/form-data"  class="ui form">
	<input type="file" class="ui compact teal basic" name="file">
</form>

2.在pop.xml中引入相关依赖,这个依赖主要是简化文件上传的流操作

<!-- https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload -->
        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.4</version>
        </dependency>

3.后端Controller的写法, 其中@RequestParam(“file”)与前端表单中< input>的name属性相对应

@PostMapping("/upload")
    public String UploadPicture(@RequestParam("file") MultipartFile file,RedirectAttributes attributes) throws IOException {
         if(file.isEmpty()){  
         // 这里是我自定义的异常,可省略
            throw new NotFindException();
        }
        // 上传文件/图像到指定文件夹(这里可以改成你想存放地址的相对路径)
        File savePos = new File("src/main/resources/static/images/imgWall");
        if(!savePos.exists()){  // 不存在,则创建该文件夹
            savePos.mkdir();
        }
        // 获取存放位置的规范路径
        String realPath = savePos.getCanonicalPath();
        // 上传该文件/图像至该文件夹下
        file.transferTo(new File(realPath+"/"+file.getOriginalFilename()));
        attributes.addFlashAttribute("message","添加成功!");
        return "redirect:/admin/pictureWall";
    }

3、本地路径获取或者linux路径获取

三个方法都是获取文件路径的,其中:

getPath() 表示获取当前文件的相对路径

getAbsolutePath() 表示获取当前文件的绝对路径+相对路径,不做解析

getCanonicalPath() 表示获取当前文件的绝对路径,解析路径

通过实例可以看到效果:

a.txt
D:\workspace\Test\TestWeb\src…\a.txt
D:\workspace\Test\TestWeb\a.txt

在linux环境下:
a.txt
/usr/local/workspace/Test/TestWeb/src/…/a.txt
/usr/local/workspace/Test/TestWeb/a.txt

或者

System.getProperty("user.dir")可以获得程序的当前路径

在任意类里通过以下代码获取resource文件夹下的某个文件(夹)的路径

String staticPath = this.getClass().getClassLoader().getResource("static").getFile();

可以实现你各种各样的目录下存放,网上大多是放到target下的某个目录,当编译项目后则会清空target目录,所以不太好,建议还是放到resouces目录下比较好。

4、实验结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐