JS FormData上传文件的设置方法
程序员文章站
2022-05-26 09:03:23
使用formdata上传文件时,总是获取不到req.file对象。发现是没有配置对formdata导致。
这里我是在vue中使用axios发送的请求,配置代码如下。重点地...
使用formdata上传文件时,总是获取不到req.file对象。发现是没有配置对formdata导致。
这里我是在vue中使用axios发送的请求,配置代码如下。重点地方给出注释
<form id="uploadform" method="post" enctype="multipart/form-data" :action="postimgapi" ref="uploadform"> <input type="file" name="imagefile" @change="upload" ref="inputfile"> </form> let uploadform = this.$refs.uploadform let inputfile = this.$refs.inputfile let formdata = new formdata(uploadform) //初始化时将form dom对象传入 formdata.append('imagefile', inputfile) //将imagefile键追加进去,值为input-file的dom对象,否则服务端无法获取file this.$http.post(this.postimgapi, formdata, { headers: { 'content-type': 'multipart/form-data' //设置post文件的请求头 } }).then(res => { debugger this.textarea = res.data })
这两天也是从网上找了各种demo和资料,发现使用自己的请求是后台就是获取不到文件,而使用form表单的submit却是可以。最开始分析是否是自己的请求头的问题,发现content-type正确且带有boundary,content-length也正常,说明请求头这里应该是没问题的。所以从formdata这里入手,几次尝试后寻找到上面代码的方式可以正常运行。这里后面有时间还是要详细分析下formdata,好好学习下在给出深度的解释。
以上所述是小编给大家介绍的js formdata上传文件的设置方法,希望对大家有所帮助