学习笔记——SpringBoot图片上传接口

本文介绍了如何在Java应用中使用Spring框架实现图片上传至本地并设置浏览器访问路径,包括创建工具类处理上传及URL生成,以及在Controller中调用该工具完成实际操作。测试过程中发现图片显示延迟问题,解决办法也一并探讨。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现在需求是:将一张图片上传到本地,并且可以通过浏览器访问。

1. 写工具类:

在utils中写一个uploadImage类,在这里配置图片上传到哪个文件夹下,并且返回图片访问地址。

package com.zhuwei.bgaccess.utils;

import org.springframework.web.multipart.MultipartFile;

import java.io.File;
import java.io.IOException;
import java.util.UUID;

/*
*上传图片所用到的工具类
* */
public class UploadImage {

    // 定义一个目标路径,就是我们要把图片上传的位置
    private static String BASE_PATH = "D:\\ideaProject\\background-management-system\\src\\main\\resources\\static\\images\\";

    // 定义访问图片路径
    private static final String SERVER_PATH = "http://localhost:8900/images/";

    public static String upload(MultipartFile file) {
        // 获取上传图片的名称
        String filename = file.getOriginalFilename();
        // 为了保证图片在服务器中名字的唯一性,使用UUID来对filename进行改写
        String uuid = UUID.randomUUID().toString().replace("-", "");
        // 将生成的uuid和filename惊醒拼接
        String newFileName = uuid + '-' + filename;
        // 创建一个文件实例对象
        File image = new File(BASE_PATH, newFileName);
        // 对这个文件进行上传操作
        try {
            file.transferTo(image);
        } catch (IOException e) {
            e.printStackTrace();
        }
        System.out.println(SERVER_PATH);
        return SERVER_PATH + newFileName;
    }
}

 2.写控制类

在controller中写一个控制类,来规定请求访问的接口,调用工具类,完成图片上传功能。

package com.zhuwei.bgaccess.controller;

import com.zhuwei.bgaccess.utils.UploadImage;
import com.zhuwei.bgaccess.utils.ResultObject;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;


@RestController
@RequestMapping("/upload")
public class ImageController {

    @RequestMapping("/image")
    public ResultObject uploadImage(@RequestParam(value = "file") MultipartFile multipartFile) {
        // 调用写好的工具类
        String imagePath = UploadImage.upload(multipartFile);

        if(imagePath == null) {
            return ResultObject.apiError("上传失败");
        } else {
            return ResultObject.ok("上传成功").data("imgUrl", imagePath);
        }
    }
}

使用postman测试,可以上传,但是在浏览器上不能立即看到图片,需要重启服务后,才可以访问图片。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一一GG

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值