文件上传是Web开发的重要组成部分。传统的文件上传有以下几种场景:
更多文件上传请移步文件上传,了解这8个场景就够了感谢作者@奇舞周刊
这里只简单叙述拖拽和多文件上传方式,使用的组件是上传
实现文件上传数据是用字符流二进制的形式,如下:
上传组件的使用:
<div id="zyupload" class="zyupload"></div>
<script src="lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script>
<script src="lib/jq-module/zyupload/zyupload-1.0.0.min.js" charset="utf-8"></script>
<script type="text/javascript">
$(function () {
// 初始化插件
$("#zyupload").zyUpload({
width: "650px", // 宽度
height: "400px", // 宽度
itemWidth: "140px", // 文件项的宽度
itemHeight: "115px", // 文件项的高度
url: "api/upload", // 上传文件的路径
fileType: ["jpg", "png", "txt", "js", "exe"],// 上传文件的类型
fileSize: 51200000, // 上传文件的大小
multiple: true, // 是否可以多个文件上传
dragDrop: true, // 是否可以拖动上传文件
tailor: true, // 是否可以裁剪图片
del: true, // 是否可以删除文件
finishDel: false, // 是否在上传文件完成后删除预览
/* 外部获得的回调接口 */
onSelect: function (selectFiles, allFiles) {
// 选择文件的回调方法 selectFile:当前选中的文件 allFiles:还没上传的全部文件
console.info("当前选择了以下文件:");
console.info(selectFiles);
},
onDelete: function (file, files) {
// 删除一个文件的回调方法 file:当前删除的文件 files:删除之后的文件
console.info("当前删除了此文件:");
console.info(file.name);
},
onSuccess: function (file, response) {
// 文件上传成功的回调方法
console.info("此文件上传成功:");
console.info(file.name);
console.info("此文件上传到服务器地址:");
console.info(response);
$("#uploadInf").append("<p>上传成功,文件地址是:" + response + "</p>");
},
onFailure: function (file, response) {
// 文件上传失败的回调方法
console.info("此文件上传失败:");
console.info(file.name);
},
onComplete: function (response) {
// 上传完成的回调方法
console.info("文件上传完成");
console.info(response);
}
});
});
</script>
后台接口:
@Controller
@RequestMapping("/api")
public class FileUpLaodController {
@CrossOrigin
@ResponseBody
@RequestMapping(value = "/upload",method = RequestMethod.POST)
public String fileUpload(@RequestParam MultipartFile file) throws IOException {
if(file.isEmpty()){
return "上传失败!";
}
else {
byte[] bytes = file.getBytes();
Path path = Paths.get("C:\\Users\\fireapproval\\Desktop\\毕业设计\\数据集\\"+file.getOriginalFilename());
Files.write(path,bytes);
// FileWriter fileWriter = new FileWriter(new File("C:\\Users\\fireapproval\\Desktop\\毕业设计\\数据集\\"+file.getOriginalFilename()));
// fileWriter.close();
}
return "C:\\Users\\fireapproval\\Desktop\\毕业设计\\数据集";
}
}
MultipartFile是Spring上传文件的封装类。它包含文件的二进制流和文件属性等信息。该文件可以是图片。
The field file exceeds its maximum permitted size of 1048576 bytes
写完前后代码后上传文件时可能会出现上述错误。这是因为spring boot默认限制最大单个文件的大小为1048576字节。
spring.servlet.multipart.max-file-size = 100MB //最大文件大小
spring.servlet.multipart.max-request-size=100MB //最大请求数量
根据 Spring Boot 版本的不同,配置可能会有所不同。这里是spring boot 2.7.1版本。
另外值得注意的是文件的写入部分:
- 修改传入文件的地址
-
注意
@CrossOrigin
解决跨域问题 -
写入文件方法及文件路径
byte[] bytes = file.getBytes();
//方法一:
Path path = Paths.get("C:\\Users\\_xiaoxu_\\数据集\\"+file.getOriginalFilename());
Files.write(path,bytes);
//方法二:
FileWriter fileWriter = new FileWriter(new File("C:\\Users\\_xiaoxu_\\数据集\\"+file.getOriginalFilename()));
fileWriter.close();
如下图所示上传成功:
. . .