SpringBoot文件上传

73 篇文章 0 订阅
52 篇文章 0 订阅

前端页面:upload.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>上传</title>
</head>
<body>
     <form enctype="multipart/form-data" method="post" action="/upload">
         文件:<input type="file" name="head_img">
         姓名:<input type="text" name="name">
         <input type="submit" value="上传">
     </form>
</body>
</html>

 

后端代码:

package net.xdclass.demo.controller;

import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.IOException;
import java.util.UUID;

@Controller
@EnableAutoConfiguration
public class FileController {
    @RequestMapping("/")
    public Object index(){
        return "index";
    }

    private static final String filePath="D:\\programme\\java\\xdclass_springboot\\src\\main\\resources\\static\\images\\";

    @RequestMapping(value = "upload")
    @ResponseBody
    public String upload(@RequestParam("head_img") MultipartFile file, HttpServletRequest request){
        //若不加MultipartFile file,文件名应与前端文件名一致
        String name = request.getParameter("name");
        System.out.println("用户名:"+name);
        //获取文件名
        String filename = file.getOriginalFilename();
        System.out.println("上传的文件名为:"+filename);

        //获取文件后缀名
        String suffixName = filename.substring(filename.lastIndexOf("."));
        System.out.println("上传的后缀为"+suffixName);
        //文件上传后的路径
        filename = UUID.randomUUID()+suffixName;//文件名使用UUID随机生成加后缀就是要保存的名称,这是为了防止上传文件名一样
        File dest = new File(filePath+filename);

        try {
            file.transferTo(dest);//把文件保存到dest路径中
            return filename;
        } catch (IllegalStateException e) {
            e.printStackTrace();
        } catch (IOException e){
            e.printStackTrace();
        }
        return "上传失败!";

    }
}

文件上传和访问需要指定磁盘路径
        application.properties中增加下面配置

  • web.images-path=/Users/jack/Desktop
  • spring.resources.static-locations=classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/,classpath:/test/,file:${web.images-path}
    classpath 指的是编译路径                         file指的是磁盘物理路径        

注:${web.images-path}表示引入配置文件内容

        spring.resources.static-locations(使用目录位置列表替换默认值)自定义静态资源位置 。如果执行此操作,默认的欢迎页面检测将切换到您的自定义位置。因此,如果index.html您的任何位置在启动时存在,它将成为应用程序的主页。

也就是说,他的作用就是告诉Spring Boot应该在何处查找静态资源文件,这是一个列表性的配置,查找文件时会依赖于配置的先后顺序依次进行,(四个静态资源目录)默认的官方配置如下:

spring.resources.static-locations=classpath:/static,classpath:/public,classpath:/resources,classpath:/META-INF/resources
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中实现文件上传非常简单。首先,你需要在项目的依赖中添加spring-boot-starter-web。然后,你可以通过配置文件来对文件上传进行一些基本的配置。例如,你可以设置是否开启文件上传支持、文件写入磁盘的阈值、上传文件的临时保存位置、上传的单个文件的最大大小以及多文件上传时文件的总大小等。\[1\] 对于单文件上传,你可以创建一个HTML表单,使用enctype="multipart/form-data"来指定表单的编码类型,并使用<input type="file">来选择文件。然后,你可以在后端编写一个处理文件上传的接口,通过@RequestParam注解来获取上传的文件。\[2\] 对于多文件上传,你可以创建一个HTML表单,使用相同的方式来选择多个文件。然后,你可以在后端编写一个处理多文件上传的接口,通过@RequestParam注解来获取上传的文件列表。\[2\] 在Spring Boot中,如果你没有提供MultipartResolver,那么默认采用的MultipartResolver就是StandardServletMultipartResolver。因此,你甚至可以实现零配置的文件上传。\[3\] 总结起来,Spring Boot提供了简单而强大的功能来实现文件上传,你只需要添加依赖、进行一些基本的配置,然后在后端编写相应的接口即可实现文件上传功能。 #### 引用[.reference_title] - *1* *2* *3* [SpringBoot文件上传](https://blog.csdn.net/qq_43581790/article/details/123811775)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值