时间:2021-05-26
使用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.uploadformlet inputfile = this.$refs.inputfilelet formData = new FormData(uploadform) //初始化时将form Dom对象传入formData.append('imagefile', inputfile) //将imagefile键追加进去,值为input-file的dom对象,否则服务端无法获取filethis.$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上传文件的设置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS+php后台实现文件上传功能。分享给大家供大家参考,具体如下:一、利用FormData对象形式上传FormData是XMLHttpReques
通过对文件的拖动实现文件的上传,主要用到的是HTML5的ondrop事件,上传内容通道FormData传输://进度条0%//要拖动到的地方js:vardz=$
本文实例讲述了php下html5XHR2+FormData+FileAPI上传文件操作。分享给大家供大家参考,具体如下:FormData的作用:FormData
html页面//注意不能带括号js代码methods:{//上传图片onUpload(e){varformData=newFormData();formData
摘要1.jquery自定义插件方法2.表单file样式调整3.利用formData,ajax上传图片4.js,css弹出层5.springmvc上传图片效果调用