文章目录

  • 前言
  • 一、区别是什么?
  • 二、使用步骤
  • 1.上传到项目的根目录下
  • 2.上传的指定文件夹下
  • 总结



前言

上传文件到本地:

  • 上传到项目的根目录下
  • 上传的指定文件夹下

一、区别是什么?

  1. 上传到项目的根目录下
    上传,访问都很方便,但是对于部署来说很不友好,linux 部署会导致找不到路径
  2. 上传的指定文件夹下
    这个上传也很方便,但是访问的时候,需要配置下项目文件上的访问映射

二、使用步骤

1.上传到项目的根目录下

代码如下(示例):

// 上传
   @PostMapping("/upload")
   public Result<?> upload(MultipartFile file) throws IOException {
        String originalFilename = file.getOriginalFilename();  // 获取源文件的名称
        // 定义文件的唯一标识(前缀)
        String flag = IdUtil.fastSimpleUUID();
        String rootFilePath = System.getProperty("user.dir") + "/files/" + flag + "_" + originalFilename;  // 获取上传的路径
        File rootFile = new File(rootFilePath);
        if (!rootFile.getParentFile().exists()) {
            rootFile.getParentFile().mkdirs();
        }
        FileUtil.writeBytes(file.getBytes(), rootFilePath);  // 把文件写入到上传的路径
        return Result.success("http://" + ip + ":" + port + "/files/" + flag);  // 返回结果 url
    }
    
   // 下载
  @GetMapping("/{flag}")
   public void getFiles(@PathVariable String flag, HttpServletResponse response) {
        OutputStream os;  // 新建一个输出流对象
        String basePath = System.getProperty("user.dir") + "/files/";  // 定于文件上传的根路径
        List<String> fileNames = FileUtil.listFileNames(basePath);  // 获取所有的文件名称
        String fileName = fileNames.stream().filter(name -> name.contains(flag)).findAny().orElse("");  // 找到跟参数一致的文件
        try {
            if (StrUtil.isNotEmpty(fileName)) {
                response.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8"));
                response.setContentType("application/octet-stream");
                byte[] bytes = FileUtil.readBytes(basePath + fileName);  // 通过文件的路径读取文件字节流
                os = response.getOutputStream();   // 通过输出流返回文件
                os.write(bytes);
                os.flush();
                os.close();
            }
        } catch (Exception e) {
            System.out.println("文件下载失败");
        }
    }

2.上传的指定文件夹下

代码如下(示例):

@PostMapping("/uploadLocation")
    public Result<?> uploadLocation(MultipartFile file) throws IOException {
        String originalFilename = file.getOriginalFilename();  // 获取源文件的名称
        // 定义文件的唯一标识(前缀)
        String flag = IdUtil.fastSimpleUUID();
        String rootFilePath = "/opt/test/" + flag + "_" + originalFilename;  // 获取上传的路径
        File rootFile = new File(rootFilePath);
        if (!rootFile.getParentFile().exists()) {
            rootFile.getParentFile().mkdirs();
        }
        FileUtil.writeBytes(file.getBytes(), rootFilePath);  // 把文件写入到上传的路径
        return Result.success("http://" + ip + ":" + port + "/file/" + flag + "_" + originalFilename);  // 返回结果 url
    }

上传和之前基本一致,然后是访问
这里我们可以省略这个下载,或者查询接口,直接通过mvc配置实现这个文件的访问

@Configuration
public class WebConfig implements WebMvcConfigurer {
	 @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        //配置拦截器访问静态资源
        registry.addResourceHandler("/file/**").addResourceLocations("file:" + "/opt/test/");
    }

}

文件上传到本地文件夹_java

当我们进行请求的时候 http://localhost:9099/file/f82f588147954330ad475e7f0ace0ebf_12123.jpg 其中 http://localhost:9099/file/ 会被配置检测到,然后导向到/opt/test/ ,可以理解为有个接口,帮我们拦截后,重定向到了那个指定的文件,或者类似nginx代理的感觉,然后继续访问f82f588147954330ad475e7f0ace0ebf_12123.jpg 这个文件


总结

文件上传到本地,建议采用后者,这样对于后续部署会方便很多,之后我会继续出一遍,整合本地文件与oss对象存储整合的文章,这样文件基本上就全了