Spring Boot 实现多文件上传

这篇具有很好参考价值的文章主要介绍了Spring Boot 实现多文件上传。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

文件上传

Spring Boot代码

  1. 代码结构:
    Spring Boot 实现多文件上传

  2. Controller层

    package com.yqifei.upload.controller;
    
    import io.swagger.annotations.Api;
    import org.springframework.web.bind.annotation.*;
    import org.springframework.web.multipart.MultipartFile;
    
    import javax.servlet.http.HttpServletRequest;
    import java.io.File;
    import java.io.IOException;
    import java.util.ArrayList;
    import java.util.List;
    import java.util.UUID;
    
    /**
     * @ClassName UploadController
     * @Description TODO
     * @Author jiangyuntao
     * @Data 2023/3/7 23:52
     * @Version 1.0
     * @Email yuntaojiang@foxmail.com
     */
    
    @RestController
    @CrossOrigin
    @RequestMapping("/posts")
    @Api(tags = "文件上传控制器")
    public class UploadController {
    
    /*
    http://localhost:8088/swagger-ui.html#
    */
        @PostMapping(value="/upload")
        @CrossOrigin
        public List<String> fileload(@RequestParam(value = "file") MultipartFile[] file, HttpServletRequest request) throws IOException {
            System.out.println(file.length);
            String savaLaction="d:/data/";
            String fileSaveName;
            List<String> imageUri = new ArrayList<>();
            for (MultipartFile multipartFile:file) {
                System.out.println("文件"+multipartFile.getOriginalFilename());
                fileSaveName = UUID.randomUUID().toString()+multipartFile.getOriginalFilename();
                multipartFile.transferTo(new File(savaLaction,fileSaveName));
                String res = request.getScheme()+"://"+request.getServerName()+":"+"8080"+savaLaction+"/"+fileSaveName;
                imageUri.add(res);
            }
            System.out.println(imageUri);
            return imageUri;
        }
    
    }
    
    
  3. 跨域拦截器配置

    package com.yqifei.upload.utils;
    
    import org.springframework.context.annotation.Configuration;
    import javax.servlet.*;
    import javax.servlet.annotation.WebFilter;
    import javax.servlet.http.HttpServletResponse;
    import java.io.IOException;
    @WebFilter(filterName = "CorsFilter")
    @Configuration
    public class CorsFilter implements Filter {
        @Override
        public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
            HttpServletResponse response = (HttpServletResponse) res;
            response.setHeader("Access-Control-Allow-Origin","*");
            response.setHeader("Access-Control-Allow-Credentials", "true");
            response.setHeader("Access-Control-Allow-Methods", "POST, GET, PATCH, DELETE, PUT");
            response.setHeader("Access-Control-Max-Age", "3600");
            response.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
            chain.doFilter(req, res);
        }
    }
    
    
  4. application.properties配置

    # 应用名称
    spring.application.name=upload
    # 应用服务 WEB 访问端口
    server.port=8088
    
    spring.web.resources.static-locations=file:d:/data/
    
    spring.servlet.multipart.max-request-size=50MB
    spring.servlet.multipart.max-file-size=50MB
    
  5. 前端页面

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="UTF-8" />
        <title>Multiple File Upload</title>
      </head>
      <body>
        <h1>Multiple File Upload</h1>
        <form>
          <input type="file" id="fileInput" multiple />
          <button type="button" onclick="uploadFiles()">Upload</button>
        </form>
        <div id="progress"></div>
        <div>图片返回值地址:</div>
        <div id="result"></div>
      </body>
      <script>
        function uploadFiles() {
          const files = document.getElementById("fileInput").files;
          const xhr = new XMLHttpRequest();
          const formData = new FormData();
    
          for (let i = 0; i < files.length; i++) {
            formData.append("file", files[i]);
          }
    
          xhr.open("POST", "http://localhost:8088/posts/upload");
          xhr.upload.addEventListener("progress", function (event) {
            if (event.lengthComputable) {
              const percent = Math.round((event.loaded / event.total) * 100);
              const progress = document.getElementById("progress");
              progress.innerHTML = "Upload progress: " + percent + "%";
            }
          });
          xhr.addEventListener("load", function (event) {
            const response = JSON.parse(event.target.responseText);
            console.log(response);
            // 在HTML页面上找到需要显示响应结果的元素
            const resultElement = document.getElementById("result");
            // 更新元素的文本内容为服务器返回的值
            resultElement.textContent = response;
          });
          xhr.send(formData);
        }
      </script>
    </html>
    
    
    
  6. 效果展示

    Spring Boot 实现多文件上传

  7. 获取图片的url并且读取图片
    Spring Boot 实现多文件上传

    1. 修改tomcat的server.xml文件

      Spring Boot 实现多文件上传

      加上下面这句文章来源地址https://www.toymoban.com/news/detail-402002.html

      <Context docBase ="/home/springbootVue/files" path ="/home/springbootVue/files" debug ="0" reloadable ="true"/>
      // 	docBase代表文件路径,path是浏览器访问时的路径。
      // 若自己创建的文件夹在tomcat目录的webapps中,不同之处: docBase直接写文件夹文字即可(注意:没有/) 例如 docBase ="home/springbootVue/files"
      

到了这里,关于Spring Boot 实现多文件上传的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring Boot + MinIO 实现文件切片极速上传技术

    🎉欢迎来到SpringBoot框架学习专栏~ ☆* o(≧▽≦)o *☆嗨~我是IT·陈寒🍹 ✨博客主页:IT·陈寒的博客 🎈该系列文章专栏:SpringBoot 📜其他专栏:Java学习路线 Java面试技巧 Java实战项目 AIGC人工智能 数据结构学习 🍹文章作者技术和水平有限,如果文中出现错误,希望大家能指

    2024年02月04日
    浏览(43)
  • minio + linux + docker + spring boot实现文件上传与下载

    检查linux内核,必须是3.10以上 安装docker 启动docker 搜索镜像 拉取镜像 启动minio -p: 指定端口映射,格式为:主机端口:容器端口 (这里注意要映射两个,否则API会访问不到) -e “MINIO_ROOT_USER=vinci” minio用户名; -e MINIO_SECRET_KEY=123456 minio 密码 -d: 后台运行容器,并返回容器ID; -

    2024年02月07日
    浏览(41)
  • JAVA面试题分享五百一十一:Spring Boot基于WebUploader实现超大文件上传和断点续传

    目录 前言 目标 实现思路 大文件分片 合并分片 断点续传 代码实现 1、webuploader组件中,分片上传怎么开启? 2、webuploader组件中,文件的md5值如何计算? 3、webuploader组件中,分片文件的md5值如何计算? 4、webuploader组件中,分片上传的的请求在哪里触发? 5、前端、后端如何校

    2024年02月19日
    浏览(40)
  • spring boot文件上传

    文件上传,是指将本地图片、视频、音频等文件上传到服务器,供其他用户浏览或下载的过程。 文件上传在项目中应用非常广泛,我们经常发微博、发微信朋友圈都用到了文件上传功能。 前端代码: 后端代码: 对于阿里云的oss的使用可阅读对象存储 OSS官方文档 导入依赖

    2024年02月08日
    浏览(37)
  • Spring Boot中实现文件上传

    要在Spring Boot中实现文件上传,可以按照以下步骤进行操作: 添加依赖:在Maven或Gradle配置文件中添加Spring Boot Web相关的依赖。 创建文件上传接口:创建一个控制器(Controller)类,定义文件上传的接口。例如: java复制代码 import org.springframework.web.bind.annotation.PostMapping; impor

    2024年02月12日
    浏览(31)
  • Spring Boot 设置上传文件大小限制

    在开发 Web 应用程序时,我们通常需要处理文件上传功能。为了确保系统的安全性和稳定性,我们需要限制上传文件的大小。本篇博客将介绍如何使用 Spring Boot 设置上传文件大小限制。 1. application.properties 配置文件 Spring Boot 提供了一种简单的方式来配置上传文件大小限制。首

    2024年02月04日
    浏览(38)
  • spring boot 上传文件的大小限制

    根据spring boot 版本不同在application.properties文件添加不同的配置 Spring Boot 1.3 或之前的版本,配置: Spring Boot 1.4 版本后配置更改为: Spring Boot 2.0 之后的版本配置修改为: 单位Mb改为MB了: 以上配置直接在配置文件中即可

    2024年02月07日
    浏览(33)
  • spring boot + minio 分布式文件上传

    1、分布式文件系统 简单理解为:一个计算机无法存储海量的文件,通过网络将若干计算机组织起来共同去存储海量的文件,去接收海量用户的请求,这些组织起来的计算机通过网络进行通信。 好处: 一台计算机的文件系统处理能力扩充到多台计算机同时处理。 一台计算机

    2024年02月08日
    浏览(45)
  • spring-boot中实现分片上传文件

    一、上传文件基本实现 1、前端效果图展示,这里使用 element-ui plus 来展示样式效果 2、基础代码如下 3、定义后端接口,并且处理好跨域(关于跨域处理,自己百度处理) 4、保存文件到本地文件 二、配置静态目录 1、在 FileApplication.java 旁边添加一个 SpringMvcConfig.java 的文件 2、直

    2024年02月05日
    浏览(40)
  • Spring Boot 中实现文件上传、下载、删除功能

    🏆作者简介,普修罗双战士,一直追求不断学习和成长,在技术的道路上持续探索和实践。 🏆多年互联网行业从业经验,历任核心研发工程师,项目技术负责人。 🎉欢迎 👍点赞✍评论⭐收藏 🔎 SpringBoot 领域知识 🔎 链接 专栏 SpringBoot 专业知识学习一 SpringBoot专栏 Sprin

    2024年01月19日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包