it编程 > 前端脚本 > Ajax

AJAX实现文件上传功能报错Current request is not a multipart request详解

160人参与 2024-06-01 Ajax

想做一个文件上传,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文件上传内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)
打赏 微信扫一扫 微信扫一扫

您想发表意见!!点此发布评论

推荐阅读

解决Ajax方式上传文件报错"Uncaught TypeError: Illegal invocation"

06-01

Ajax使用异步对象发送请求方案详解

05-28

Django使用AJAX向服务器发起请求的操作方法

06-17

ajax异步读取后台传递回的下拉选项的值方法

05-19

浅析IE浏览器关于ajax的缓存机制

05-19

Fly拦截全局Ajax请求的方法

05-19

猜你喜欢

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

发表评论