【问题标题】:Error on uploading one image by ajax [closed]通过ajax上传一张图片时出错[关闭]
【发布时间】:2014-08-27 19:20:50
【问题描述】:

我无法通过 ajax 上传单个文件。这是我的代码。

JS 文件

var _submit = document.getElementById('fileInputBox');
var formData = new FormData();
formData.append('upload', 'upload'); 
formData.append('SelectedFile', _submit.files[0]);

$('#fileInputBox').on('change', function (e) {
  e.preventDefault();

  $.ajax({
    url: 'upload2.php',
    type: 'POST',
    data: formData,
    dataType: 'json' ,
    async: false,
    cache: false,
    contentType: false,
    processData: false,
    success: function (data) {
       $('#sep_s').html(data.msg); 
    }

 });

  // return false;
});

HTML 文件

  <form action="" method="post" enctype="multipart/form-data" name="UploadForm" id="UploadForm">

     <div id="AddFileInputBox">
          <input id="fileInputBox" style="margin-bottom: 5px;" type="file"  name="file"/>
     </div>
  </form>

PHP 文件

  if(isset($_POST['upload']))
  {
     $ImageName         = $_FILES['file']['name'];
     $ImageSize         = $_FILES['file']['size'];
        $TempSrc        = $_FILES['file']['tmp_name'];
      $ImageType        = $_FILES['file']['type'];
    ..........

我得到的错误是

通知:未定义索引:G:\installed here\upload2.php 中的文件16
通知:未定义的索引:G:\installed here\upload2.php 中的文件 17
等等。

这里有什么问题?

【问题讨论】:

标签: php jquery html ajax file-upload


【解决方案1】:

我可以看到的一个问题是,您在页面加载时附加图像,而不是在实际设置/更改时附加图像。

您应该将该代码放入事件处理程序中:

$('#fileInputBox').on('change', function () {

  // put this inside the function so that its get set when you assign a value
  var _submit = document.getElementById('fileInputBox');
  var formData = new FormData();
  formData.append('upload', 'upload'); 
  formData.append('SelectedFile', _submit.files[0]);

  $.ajax({
    url: 'upload2.php',
    type: 'POST',
    data: formData,
    dataType: 'json' ,
    async: false,
    cache: false,
    contentType: false,
    processData: false,
    success: function (data) {
       $('#sep_s').html(data.msg); 
    }

  });
});

【讨论】:

  • 可能不需要e.preventDefault()。更改文件输入没有任何额外的默认操作。
  • 非常感谢,您的也可以,+ 将文件重命名为 SelectedFile。
  • @Barmar 你是对的,我什至没有注意到,只是复制了 OP 的代码......
【解决方案2】:

你在formdata中使用SelectedFile作为参数,但在php中使用file,例如

$ImageName = $_FILES['SelectedFile']['name'];

您还需要在更改事件处理程序中获取要上传的文件,即实际选择文件的时间。

$('#fileInputBox').on('change', function (e) {
  var _submit = document.getElementById('fileInputBox');
  var formData = new FormData();
  formData.append('upload', 'upload'); 
  formData.append('SelectedFile', _submit.files[0]);
  ...

【讨论】:

  • 这也是我得到Undefined index: SelectedFile in ...
  • 哇,谢谢:) 你救了我:)。它就像一个魅力,我不知道我必须将它们放在更改处理程序中。非常感谢。
猜你喜欢
  • 2017-03-27
  • 1970-01-01
  • 2021-12-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-31
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多