SpringBoot文件上传下载

package com.example.controller;

import com.example.common.Result;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.UUID;

@RestController
@RequestMapping("/files")
@Slf4j
public class FileController {

    @Value("${files.upload.path}")
    private String basePath;

    /**
     * 文件上传
     * @param file
     * @return
     */
    @PostMapping("/upload")
    public Result upLoad(MultipartFile file) {
        //file是一个临时文件 需要转存到指定位置 否则本次请求完成后会被删除
        log.info(file.toString());
        //原始文件名
        String originalFilename = file.getOriginalFilename();
        String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
        //使用UUID重新生成唯一文件名
        String fileName = UUID.randomUUID().toString() + suffix;

        //如果目录不存在 创建一个目录用于存放转存的图片
        File dir = new File(basePath);
        if (!dir.exists()) {
            dir.mkdirs();
        }

        try {
            //将图片转存到指定位置
            file.transferTo(new File(basePath + fileName));
        } catch (IOException e) {
            e.printStackTrace();
        }
        return Result.success(fileName);
    }


    /**
     * 文件下载
     *
     * @param name
     * @param response
     */
    @GetMapping("/download/{name}")
    public void download(@PathVariable String name, HttpServletResponse response) {

        try {
            //输入流,通过输入流读取文件内容
            FileInputStream fileInputStream = new FileInputStream(new File(basePath + name));

            //输出流,通过输出流将文件写回浏览器
            ServletOutputStream outputStream = response.getOutputStream();

//            response.setContentType("image/jpeg");
            response.setContentType("application/octet-stream");  //流的形式下载
            int len = 0;
            byte[] bytes = new byte[1024];
            while ((len = fileInputStream.read(bytes)) != -1) {
                outputStream.write(bytes, 0, len);
                outputStream.flush();
            }
            //关闭资源
            outputStream.close();
            fileInputStream.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

在Vue中使用 例如头像上传与显示

   <el-upload class="avatar-uploader" action="http://localhost:9090/files/upload" :show-file-list="false"
                :on-success="handleAvatarSuccess">
                <img v-if="'http://localhost:9090/files/download/'+form.avatar" :src="'http://localhost:9090/files/download/'+form.avatar" class="avatar">
                <i v-else class="el-icon-plus avatar-uploader-icon"></i>
            </el-upload>
<script>
  handleAvatarSuccess(res) {
            this.form.avatar = res.data
        }
</script>

<el-table-column prop="image" label="图片" align="center">
                <template #default="scope">
                    <el-image style="width: 40px; height: 40px" preview-teleported="true"
                        :src="'http://localhost:9090/files/download/' + scope.row.avatar"
                        :preview-src-list="['http://localhost:9090/files/download/'+scope.row.avatar]">
                    </el-image>
                </template>         
            </el-table-column>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

不想再掉头发了.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值