【SpringBoot】39、SpringBoot上传文件至项目resources目录下

【SpringBoot】39、SpringBoot上传文件至项目resources目录下当我们没有搭建单独的文件服务器时,我们需要将文件上传至项目目录下,今天我们就学习如何上传文件到项目的resources目录下一、引入依赖<dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version></depende

大家好,又见面了,我是你们的朋友全栈君。

当我们没有搭建单独的文件服务器时,我们需要将文件上传至项目目录下,今天我们就学习如何上传文件到项目的resources目录下

一、引入依赖

<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.3</version>
</dependency>
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.6</version>
</dependency>
<dependency>
    <groupId>commons-net</groupId>
    <artifactId>commons-net</artifactId>
    <version>3.3</version>
</dependency>

文件上传,就会涉及到 IO 操作,我们需要引入以上依赖

二、配置文件

spring:
  # 上传文件
  servlet:
    multipart:
      max-file-size: 10MB
      max-request-size: 10MB

配置上传文件的最大值:

  • spring.servlet.multipart.max-file-size,限制单个文件的最大值
  • spring.servlet.multipart.max-request-size,限制上传的多个文件的总大小

三、上传工具类

package com.asurplus.common.utils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.util.ResourceUtils;
import org.springframework.web.multipart.MultipartFile;
import java.io.File;
import java.net.InetAddress;
import java.util.UUID;
/** * 文件上传 * * @author YangXiuTeng * @date Jun 1, 2015 */
@Component
public class UploadFileUtil { 

/** * 项目端口 */
@Value("${server.port}")
public String port;
/** * 项目路径 */
@Value("${server.servlet.context-path}")
public String contextPath;
/** * 上传文件 * * @param multipartFile 文件对象 * @param dir 上传目录 * @return */
public ResponseResult uploadFile(MultipartFile multipartFile, String dir) { 

try { 

if (multipartFile.isEmpty()) { 

return ResponseResult.error("请选择文件");
}
// 获取文件的名称
String originalFilename = multipartFile.getOriginalFilename();
// 文件后缀 例如:.png
String fileSuffix = originalFilename.substring(originalFilename.lastIndexOf("."));
// uuid 生成文件名
String uuid = String.valueOf(UUID.randomUUID());
// 根路径,在 resources/static/upload
String basePath = ResourceUtils.getURL("classpath:").getPath() + "static/upload/" + (StringUtils.isNotBlank(dir) ? (dir + "/") : "");
// 新的文件名,使用uuid生成文件名
String fileName = uuid + fileSuffix;
// 创建新的文件
File fileExist = new File(basePath);
// 文件夹不存在,则新建
if (!fileExist.exists()) { 

fileExist.mkdirs();
}
// 获取文件对象
File file = new File(basePath, fileName);
// 完成文件的上传
multipartFile.transferTo(file);
// 返回绝对路径
return ResponseResult.success("上传成功", "http://" + InetAddress.getLocalHost().getHostAddress() + ":" + port + contextPath + "/upload/" + fileName);
} catch (Exception e) { 

e.printStackTrace();
}
return ResponseResult.error("上传失败");
}
}
  • 我们由于需要在工具类中获取项目端口及上下文路径,所以我们使用注解 @Component
  • 我们上传的根目录在:resources/static/upload
  • 文件名,我们使用了 uuid 作为新的文件名,保证文件不会被覆盖
  • 我们返回的路径是绝对路径,在实际的生成环境中,建议使用相对路径
  • ResponseResult 是我们自定义的统一返回对象,表示成功还是失败

四、上传调用

  • 1、注入上传工具类
@Autowired
private UploadFileUtil uploadFileUtil;
  • 2、上传 API
/** * 上传文件 * <p> * Ajax方式上传文件 * * @return */
@PostMapping("uploadFileAjax")
@ResponseBody
public ResponseResult uploadFileAjax(HttpServletRequest request) { 

MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request;
MultipartFile file = multiRequest.getFile("files");
String dir = request.getHeader("Minio-dir");
return uploadFileUtil.uploadFile(file, dir);
}
  • 3、上传调用

Html

<p>ajax提交</p>
<hr>
<div style="height: 200px;width: 200px;position: relative;border: 1px #e2e2e2 solid">
<input type="file" accept="image/*" id="imgUpload" style="position: absolute;left: 0;top: 0;opacity: 0;filter: alpha(opacity=0);height: 100%;width: 100%;z-index: 99">
<img src="" alt="" id="picImg" style="height: 100%;width: 100%;position: absolute;left: 0;top: 0;">
</div>

JavaScript

$('#imgUpload').change(function () { 

var formData = new FormData();
formData.append("files", $("#imgUpload")[0].files[0]);
var index = layer.load();
$.ajax({ 

type : "POST",
cache: false,
dataType: "json",
data : formData,
processData :  false,
contentType :  false,
url: baseUrl + 'uploadFileAjax',
success:function(res){ 

layer.close(index);
layer.msg(res.msg);
if(200 == res.code){ 

$('#picImg').attr('src',res.data);
}
},
error:function() { 

layer.close(index);
layer.msg("服务器异常!");
}
});
});

五、上传测试

上传元素
点击上传

上传成功
图片上传成功,转到上传目录:

上传目录
成功上传至项目的 resources/static/upload/ 目录下

如您在阅读中发现不足,欢迎留言!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/130856.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 第十一讲:独立成分分析(Independent Components Analysis )

    第十一讲:独立成分分析(Independent Components Analysis )接下来我们要讲的主体是独立成分分析(IndependentComponentsAnalysis,缩写为ICA)。这个方法和主成分分析(PCA)类似,也是要找到一组新的基向量(basis)来表征(represent)样本数据。然而,这两个方法的目的是截然不同的。还是先用“鸡尾酒会问题(cocktailpartyproblem)”为例。在一个聚会场合中,有n个人同时说话,而屋子里的任意…

  • 查看Linux版本

    查看Linux版本

    2021年10月18日
  • 怎么新建pytest的ini文件_bikini

    怎么新建pytest的ini文件_bikini前言pytest配置文件可以改变pytest的运行方式,它是一个固定的文件pytest.ini文件,读取配置信息,按指定的方式去运行查看pytest.ini的配置选项pytest-h找到以下

  • 计算机二级考试公共基础知识题库_公共基础知识计算机二级

    计算机二级考试公共基础知识题库_公共基础知识计算机二级计算机等级考试二级必须考公共基础知识,计算机二级考核计算机基础知识和使用一种高级计算机语言编写程序以及上机调试的基本技能。考试科目:语言程序设计(C、C++、Java、VisualBasic、WEB)、数据库程序设计(VisualFoxPro、Access、MySQL)、办公软件(MSOffice高级应用)共九个科目。新增”MySQL数据库程序设计”、”WEB程序设计”、”MSOffice高级应用…

  • 关闭单节点oracle,oracle rac 如何正确的删除单个节点的actionlist[通俗易懂]

    关闭单节点oracle,oracle rac 如何正确的删除单个节点的actionlist[通俗易懂]1节点2使用dbca删除一个节点2节点1alterdatabasedisablethread2;3节点1验证是否已经删除一个节点数据库[03:49:06oracle(db)@rac1~]$srvctlconfigdatabase-dprodDatabaseuniquename:prodDatabasename:prodOraclehome:/u01/app/or…

    2022年10月19日
  • linux启动网络服务步骤_centos7启动网络服务命令

    linux启动网络服务步骤_centos7启动网络服务命令linux系统下重启网络服务的两种方法发布时间:2020-04-0211:25:25来源:亿速云阅读:207作者:小新今天小编给大家分享的是linux系统下重启网络服务的两种方法,很多人都不太了解,今天小编为了让大家更加了解linux系统下重启网络服务的方法,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。Linux启动、关闭、重启网络服务的两种方式:1、使用service脚本来调…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号