AJAX实现文件上传功能报错Current request is not a multipart request详解(ajax实现分页)这都可以?

随心笔谈2年前发布 编辑
177 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



想做一个文件上传,spring boot配合Ajax来进行。却报错:Current request is not a multipart request

这是错误截图:

当时发生这种错误,我是很震惊的,我以为找了很多办法来解决。

有以下办法,当然这些并未解决我的问题,但是部分有用,就先列举出来:

1.在页面头部加入信息:

<meta http-equiv=”Content-Type” content=”multipart/form-data; charset=utf-8″ />

此方法 未解决 问题!

2.在form表单加入属性:enctype

<form method=”post” enctype=”multipart/form-data”>
<input type=”file” name=”file” />
</form>

此方法 未解决 问题!

3.后端:@RequestParam MultipartFile file 改为 @RequestPart MultipartFile file

此方法 未解决 问题!

还有个别方法。。。都不行

下面是解决方法,我之前的ajax代码:

$(‘#upload-ok’).click(function () {
var form=document.getElementById(“upload-form”);
var file=new FormData(form);
$.ajax({
url: “/addFile”,
type: “POST”,
processData:false,
contentType:false,
data:{
“file”:file
},
success: function (date) {
xxxxxx
},
error: function (date) {
xxxxxx
}
})
})

正确代码:

$(‘#upload-ok’).click(function () {
var form=document.getElementById(“upload-form”);
var file=new FormData(form);
$.ajax({
url: “/addFile”,
type: “POST”,
processData:false,
contentType:false,
//重要部分,data的传的是整个表单,不用大括号包裹;不用自定义变量名
data:file,
success: function (date) {
xxxxxx
},
error: function (date) {
xxxxxx
}
})
})

就这样,解决!!!

到此这篇关于AJAX实现文件上传功能报错Current request is not a multipart request详解的文章就介绍到这了,更多相关AJAX文件上传内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:Ajax实现上传图像功能的示例详解ajaxFileupload实现多文件上传功能基于Ajaxupload的多文件上传操作Ajax配合Spring实现文件上传功能代码Ajax实现文件上传功能(Spring MVC)

© 版权声明

相关文章