SpringBoot实现文件/图片的上传与下载

  • 导入依赖(pom.xml)

复制代码
     <!-- 上传下载需要设计到的jar包 -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.6</version>
        </dependency>
        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.3.3</version>
        </dependency>
        <!--servlet-api导入高版本的-->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
        </dependency>
        <!-- 图片处理类 -->
        <dependency>
            <groupId>net.coobird</groupId>
            <artifactId>thumbnailator</artifactId>
            <version>0.4.8</version>
        </dependency>
复制代码
  • 全局配置 application.properties

# 上传文件大小
spring.servlet.multipart.max-file-size=5MB
spring.servlet.multipart.max-request-size=5MB
  • 创建 WebMvcConfig 配置类  静态资源映射

复制代码
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        ApplicationHome h = new ApplicationHome(getClass());
        File jarF = h.getSource();
        String dirPath = jarF.getParentFile().toString()+"/upload/";

        String os = System.getProperty("os.name");

        if (os.toLowerCase().startsWith("win")) {  //如果是Windows系统
            registry.addResourceHandler("/upload/**").addResourceLocations("file:"+dirPath);
        } else {
            registry.addResourceHandler("/upload/**").addResourceLocations("file:"+dirPath);
        }
    }

}
复制代码
  • 文件或图片上传

  • 控制层
复制代码
// 上传文件
    @ResponseBody
    @RequestMapping("/upload")
    public String fileUpload(@RequestParam("files") MultipartFile files) throws IOException {
//        // win系统 上传路径保存设置
//        // 获取项目路径
//        File projectPath = new File(ResourceUtils.getURL("classpath:").getPath());
//        // 绝对路径=项目路径+自定义路径
//        File pathFile = new File(projectPath.getAbsolutePath(), "static/upload/");
//        if (!pathFile.exists()) {
//            pathFile.mkdirs();
//        }
//        //上传文件地址
//        UUID uuid = UUID.randomUUID();
//        File serverFile = new File(pathFile, uuid + "_" + files.getOriginalFilename());
//        files.transferTo(serverFile);
//
//        String imgPath = ("/upload/" + uuid + "_" + files.getOriginalFilename()).replace("\\", "/");
//
//        return imgPath;

        // Linux服务器  上传路径保存设置
        // 项目路径  /home/www/
        File pathFile = new File("/home/www/upload/");
        if (!pathFile.exists()) {
            pathFile.mkdirs();
        }
        //上传文件地址
        UUID uuid = UUID.randomUUID();
        File serverFile = new File(pathFile, uuid + "_" + files.getOriginalFilename());
        files.transferTo(serverFile);

        String imgPath = ("/upload/" + uuid + "_" + files.getOriginalFilename()).replace("\\", "/");

        return imgPath;
    }
复制代码
  • HTML页面    Ajax 无刷新上传 

复制代码
<form action="" class="layui-form" enctype="multipart/form-data" method="post">
  <input type="hidden" name="blogImg" id="imgPath" value="">
  <div class="form-group">
    <label>图片上传</label>
    <input type='file' style='margin: 5px;' name='files' required><br>
    <button type="button" class="layui-btn" id="img_upload">上传图片</button>
  </div>
  <input type="submit">
</form>
复制代码
  • JS

复制代码
//普通图片上传
        $('#img_upload').click(function () {
            var formData = new FormData();
            //获取选择的文件
            $.each($('input[name="files"]'),function (index,item) {
                formData.append("files",item.files[0])
            });

            //发送异步请求
            $.ajax({
                method:'post',
                url: '[[@{/user/upload}]]', // 文件上传接口
                data:formData,
                processData: false,
                contentType:false,
                success:function (data) {
                    //成功返回触发的方法
                    $('#imgPath').val(data);
                    alert("上传成功");
                },
                //请求失败触发的方法
                error:function () {
                    alert("上传失败");
                }
            });
        });
复制代码
  • 文件或图片下载

  • 控制层
复制代码
@RequestMapping(value="/download")
public String downloads(HttpServletResponse response ,HttpServletRequest request) throws Exception{
   //要下载的图片地址
   String  path = request.getServletContext().getRealPath("/upload");
   String  fileName = "基础语法.jpg";

   //1、设置response 响应头
   response.reset(); //设置页面不缓存,清空buffer
   response.setCharacterEncoding("UTF-8"); //字符编码
   response.setContentType("multipart/form-data"); //二进制传输数据
   //设置响应头
   response.setHeader("Content-Disposition",
           "attachment;fileName="+URLEncoder.encode(fileName, "UTF-8"));

   File file = new File(path,fileName);
   //2、 读取文件--输入流
   InputStream input=new FileInputStream(file);
   //3、 写出文件--输出流
   OutputStream out = response.getOutputStream();

   byte[] buff =new byte[1024];
   int index=0;
   //4、执行 写出操作
   while((index= input.read(buff))!= -1){
       out.write(buff, 0, index);
       out.flush();
  }
   out.close();
   input.close();
   return null;
}
复制代码
  • HTML页面  

<a href="/download">点击下载</a>

 

参考资料:狂神说SpringMVC:文件上传下载

posted @   風青宇  阅读(4111)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
阅读排行:
· 在外漂泊的这几年总结和感悟,展望未来
· 博客园 & 1Panel 联合终身会员上线
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· https证书一键自动续期,帮你解放90天限制
· 在 ASP.NET Core WebAPI如何实现版本控制?
点击右上角即可分享
微信分享提示