为了账号安全,请及时绑定邮箱和手机立即绑定

使用Ajax XmlHttpRequest上传文件

使用Ajax XmlHttpRequest上传文件

慕桂英3389331 2019-08-08 15:39:20
使用Ajax XmlHttpRequest上传文件嗨,我正在尝试使用此代码发送带有xmlhttprequest的文件。<script>     var url= "http://localhost:80/....";     $(document).ready(function(){         document.getElementById('upload').addEventListener('change', function(e) {             var file = this.files[0];             var xhr = new XMLHttpRequest();             xhr.file = file; // not necessary if you create scopes like this             xhr.addEventListener('progress', function(e) {                 var done = e.position || e.loaded, total = e.totalSize || e.total;                 console.log('xhr progress: ' + (Math.floor(done/total*1000)/10) + '%');             }, false);             if ( xhr.upload ) {                 xhr.upload.onprogress = function(e) {                     var done = e.position || e.loaded, total = e.totalSize || e.total;                     console.log('xhr.upload progress: ' + done + ' / ' + total + ' = ' + (Math.floor(done/total*1000)/10) + '%');                 };             }             xhr.onreadystatechange = function(e) {                 if ( 4 == this.readyState ) {                     console.log(['xhr upload complete', e]);                 }             };             xhr.open('post', url, true);             xhr.setRequestHeader("Content-Type","multipart/form-data");             xhr.send(file);         }, false);     });</script>但我得到了这个错误:请求被拒绝,因为没有找到多部分边界帮助我..
查看完整描述

1 回答

?
守候你守候我

TA贡献1802条经验 获得超10个赞

  1. 没有这样的事情xhr.file = file;; 文件对象不应该以这种方式附加。

  2. xhr.send(file)不发送文件。您必须使用该FormData对象将文件包装到multipart/form-datapost数据对象中:

    var formData = new FormData();formData.append("thefile", file);xhr.send(formData);

之后,可以访问该文件$_FILES['thefile'](如果您使用的是PHP)。

请记住,MDCMozilla Hack演示是您最好的朋友。

编辑:上面的(2)是不正确的。它确实发送文件,但它会将其作为原始发布数据发送。这意味着您必须自己在服务器上解析它(而且通常不可能,取决于服务器配置)。了解如何在PHP中获得的原始数据后这里


查看完整回答
反对 回复 2019-08-08
  • 1 回答
  • 0 关注
  • 628 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信