SpringBoot 文件或图片上传与下载功能的实现

 更新时间:2021年02月26日 09:21:54   作者:风青宇  
这篇文章主要介绍了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" rel="external nofollow" >点击下载</a>

SpringBoot 文件或图片上传与下载就可以了

到此这篇关于SpringBoot 文件或图片上传与下载功能的实现的文章就介绍到这了,更多相关SpringBoot 文件上传与下载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Scanner输入两个数组的方法

    Java Scanner输入两个数组的方法

    今天小编就为大家分享一篇Java Scanner输入两个数组的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • Tomcat中session的管理机制

    Tomcat中session的管理机制

    这篇文章主要为大家详细介绍了Tomcat中session的管理机制 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • SpringBoot配置Email发送功能实例

    SpringBoot配置Email发送功能实例

    本篇文章主要介绍了SpringBoot配置Email发送功能实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Spring AOP有多少个通知以及它们的执行顺序介绍

    Spring AOP有多少个通知以及它们的执行顺序介绍

    这篇文章主要介绍了Spring AOP有多少个通知以及它们的执行顺序,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • java原生序列化和Kryo序列化性能实例对比分析

    java原生序列化和Kryo序列化性能实例对比分析

    这篇文章主要介绍了java原生序列化和Kryo序列化性能实例对比分析,涉及Java和kryo序列化和反序列化相关实例,小编觉得很不错,这里分享给大家,希望给大家一个参考。
    2017-10-10
  • java MongoDB实现列表分页查询的示例代码

    java MongoDB实现列表分页查询的示例代码

    本文主要介绍了java MongoDB实现列表分页查询的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • java中的可变参数使用方法

    java中的可变参数使用方法

    这篇文章主要介绍了java中的可变参数使用方法的相关资料,需要的朋友可以参考下
    2017-06-06
  • jar中VO的探究

    jar中VO的探究

    这篇文章主要介绍了jar中VO的探究的相关资料,需要的朋友可以参考下
    2023-11-11
  • Spring Cloud Gateway的配置与使用教程

    Spring Cloud Gateway的配置与使用教程

    这篇文章主要介绍了Spring Cloud Gateway的配置与使用,通过本文的介绍,我们了解了Spring Cloud Gateway的核心概念和基本配置,需要的朋友可以参考下
    2023-06-06
  • JAVA使用爬虫抓取网站网页内容的方法

    JAVA使用爬虫抓取网站网页内容的方法

    这篇文章主要介绍了JAVA使用爬虫抓取网站网页内容的方法,实例分析了java爬虫的两种实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07

最新评论