Springboot 上传文件/图片

public String upload(MultipartFile file, Integer dir) {

        //文件上传
        String targetFilePath = "D:\\xxx\\yiyimanager\\src\\assets\\imagess";
        //获取当前文件的磁盘路径
//        System.getProperty("user.dir");
//        ClassUtils.getDefaultClassLoader().getResource("").getPath();

        File filepath = new File(targetFilePath);
        if (!filepath.exists()) {
            filepath.mkdirs();
        }

       /* //检查文件是否为空
        if(file.isEmpty()) {
            return "请选择图片";
        }
        //检查文件大小
        if(file.getSize() > Constant.M2_TO_BYTE) {
            return "请上传2M以内的图片";
        }
        //检查是否是图片
        BufferedImage bi = ImageIO.read(file.getInputStream());
        if(bi == null){
            return "上传的文件不是图片";
        }*/
        //文件原本的名字
        String originalFilename = file.getOriginalFilename();

        String fileName = UUID.randomUUID().toString().replace("-", "");
        File targetFile = new File(targetFilePath + File.separator + fileName + ".jpg");
        FileOutputStream fileOutputStream = null;
        try {
            fileOutputStream = new FileOutputStream(targetFile);
            IOUtils.copy(file.getInputStream(), fileOutputStream);
            //file.transferTo(new File(targetFilePath + File.separator + fileName + ".jpg"));//将传来的文件写入新建的文件
        } catch (IOException e) {
            System.out.println(e.getMessage());
        } finally {
            try {
                fileOutputStream.close();
            } catch (IOException e) {
                System.out.println(e.getMessage());
            }
        }
        return targetFile.toString();
    }

文件的MIMEType类型

浏览器通常使用MIME类型(而不是文件扩展名)来确定如何处理文档;因此服务器设置正确以将正确的MIME类型附加到响应对象的头部是非常重要的。

语法

通用结构 type/subtype

MIME的组成结构非常简单;由类型与子类型两个字符串中间用’/'分隔而组成。不允许空格存在。*type *表示可以被分多个子类的独立类别。subtype 表示细分后的每个类型。

MIME类型对大小写不敏感,但是传统写法都是小写。

类型描述典型示例
text表明文件是普通文本,理论上是人类可读text/plain, text/html, text/css, text/javascript
image表明是某种图像。不包括视频,但是动态图(比如动态gif)也使用image类型image/gif, image/png, image/jpeg,
audio表明是某种音频文件audio/midi, audio/mpeg, audio/webm, audio/ogg, audio/wav
video表明是某种视频文件video/webm, video/ogg
application表明是某种二进制数据application/octet-stream, application/pkcs12, application/vnd.mspowerpoint,
### Spring Boot 文件图片上传示例 #### 项目准备 为了实现文件图片上传功能,首先需要创建一个基于 Spring Boot 的项目,并在 `pom.xml` 中引入必要的依赖项。以下是常用的依赖项列表: ```xml <dependencies> <!-- Spring Boot Web Starter --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- Thymeleaf Template Engine --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!-- Commons IO (可选, 处理文件操作) --> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.11.0</version> </dependency> </dependencies> ``` #### 配置文件设置 在项目的 `application.properties` 或 `application.yml` 文件中,配置文件上传的相关参数。这些参数用于限制单个文件和整个请求的最大大小。 ```properties # 单个文件最大值 spring.servlet.multipart.max-file-size=10MB # 整体请求最大值 spring.servlet.multipart.max-request-size=10MB # JSP视图解析器(如果使用JSP) spring.mvc.view.prefix=/WEB-INF/jsp/ spring.mvc.view.suffix=.jsp ``` 以上配置确保了文件上传的安全性和性能[^2]。 #### 控制器代码 控制器负责处理文件上传请求并保存文件到指定路径。以下是一个完整的示例代码片段: ```java import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import java.io.File; import java.util.UUID; @RestController @RequestMapping("/api/file") public class FileUploadController { private static final String UPLOAD_DIR = "E:/Vue/imgs/"; @PostMapping("/upload") public String uploadFile(@RequestParam("file") MultipartFile file) { try { // 获取原始文件名 String originalFilename = file.getOriginalFilename(); if (originalFilename != null && !file.isEmpty()) { // 提取扩展名 String extension = originalFilename.substring(originalFilename.lastIndexOf(".")); // 构建新的唯一文件名 String newFileName = UUID.randomUUID() + extension; // 将文件写入目标位置 file.transferTo(new File(UPLOAD_DIR + newFileName)); return "文件上传成功:" + newFileName; } else { return "请选择有效的文件"; } } catch (Exception e) { return "文件上传失败:" + e.getMessage(); } } } ``` 此代码实现了基本的文件接收逻辑,并通过 `UUID` 来生成唯一的文件名以防止覆盖已有文件[^4]。 #### 前端页面 可以使用 HTML 表单配合 Thymeleaf 渲染前端界面。下面是一段简单的表单代码: ```html <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <title>文件上传</title> </head> <body> <h1>上传文件</h1> <form method="POST" action="/api/file/upload" enctype="multipart/form-data"> <input type="file" name="file"/> <button type="submit">上传</button> </form> </body> </html> ``` 这段代码定义了一个支持文件上传的表单,其中 `enctype="multipart/form-data"` 是关键属性之一[^1]。 --- ### 注意事项 - **安全性**:建议对上传文件类型进行校验,仅允许特定类型的文件上传。 - **存储优化**:对于大规模应用,推荐将文件存储至云端服务(如阿里云 OSS、AWS S3),而非本地磁盘。 - **异常处理**:完善错误捕获机制,提供友好的提示信息给用户。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值