通过表单和 XMLHttpRequest 异步上传文件到服务器

黑色的

我只需要使用 vanilla.js 上传文件,不允许使用任何框架。

形式:

<form id="fileUploadForm" action="fileUpload.php" method="post" enctype="multipart/form-data">
    <input type="file" name="fileToUpload" id="fileToUpload">
</form>

我将按钮放在表单之外,因为它位于 HTML 中的另一个位置。

<button id="btnUpload">Upload</button>

这是上传脚本。我正在使用FormData来获取表单数据,如本答案中所述

<script>

document.getElementById("btnUpload").addEventListener("click", function() {
    fileUpload("fileUploadForm");
});

function fileUpload(pFormId) 
{
    debugger;
    var form = document.getElementById(pFormId);
    var formData = new FormData( form );  //returns no data!

    var request = getHttpRequest();
    request.onreadystatechange = function() {
        if (request.readyState === 4 && request.status === 200) {
              console.log("Response Received");
              document.getElementById("debug").innerHTML = request.responseText;

        }
    };
    request.open("POST", "fileUpload.php", true);
//    request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    request.setRequestHeader("Content-type","multipart/form-data");
    formData.append("action","test");  //Add additional POST param
    request.send(formData);
}

function getHttpRequest() 
{
    let xmlhttp;
    if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
    } else {// code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }

    return xmlhttp;
}
</script>

我正在使用此处的 PHP 上传脚本

<?php

$target_dir = "uploads/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = strtolower(pathinfo($target_file,PATHINFO_EXTENSION));
// Check if image file is a actual image or fake image
if(isset($_POST["submit"])) {
    $check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
    if($check !== false) {
     echo "File is an image - " . $check["mime"] . ".";
        $uploadOk = 1;
    } else {
        echo "File is not an image.";
        $uploadOk = 0;
    }
}
// Check if file already exists
if (file_exists($target_file)) {
    echo "Sorry, file already exists.";
    $uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
    echo "Sorry, your file is too large.";
    $uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
    echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
    $uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
    echo "Sorry, your file was not uploaded.";
// if everything is ok, try to upload file
} else {
    if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
        echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded.";
    } else {
        echo "Sorry, there was an error uploading your file.";
    }
}

我将调试器附加到我的 javascript 并发现它formData是空的并且不包含该文件。在此处输入图片说明

这是我从 PHP 得到的:

在此处输入图片说明 抱歉,文件已经存在。

在此处输入图片说明 抱歉,只允许使用 JPG、JPEG、PNG 和 GIF 文件。抱歉,您的文件未上传。

即使该文件确实不是已经存在,文件格式为JPG。


更新:

这是我在开发者控制台网络选项卡中得到的:

Request Payload:
------WebKitFormBoundaryKjnjAyPoCQ7MU1x6
Content-Disposition: form-data; name="fileToUpload"; filename="Koala.jpg"
Content-Type: image/jpeg


------WebKitFormBoundaryKjnjAyPoCQ7MU1x6--

我感谢任何帮助!

马丁·阿达梅克

只需删除content-type标题,浏览器会在使用时自动设置FormData这样 content-type 也将包含用于分隔表单数据的表单边界(类似于------WebKitFormBoundaryKjnjAyPoCQ7MU1x6--分隔负载数据的东西)。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

通过网站上传文件到SFTP服务器

来自分类Dev

如何使用FormData和XmlHTTPRequest上传文件?

来自分类Dev

如何在服务器上手动取消XMLHttpRequest文件上传(流)

来自分类Dev

如何在服务器上手动取消XMLHttpRequest文件上传(流)

来自分类Dev

如何通过Ajax下载XMLHTTPRequest加载的文件

来自分类Dev

通过XMLHttpRequest()与PHP文件进行AJAX连接

来自分类Dev

发送XMLHttpRequest和信息服务器不发送任何确认

来自分类Dev

服务器端请求和XmlHTTPRequest(客户端)和安全性

来自分类Dev

基本的hello world服务器和Xmlhttprequest客户端-状态始终为0

来自分类Dev

具有Node.js的服务器和具有XMLHttpRequest的客户端

来自分类Dev

PHP表单文件上传到Mysql和服务器

来自分类Dev

通过发布将文件上传到服务器OutOfMemory

来自分类Dev

通过网站将文件上传到SFTP服务器

来自分类Dev

通过rtmps + java在服务器上上传文件

来自分类Dev

通过php在服务器apache上上传文件

来自分类Dev

XMLHttpRequest到.js文件

来自分类Dev

使用AngularJS和php服务器脚本上传文件

来自分类Dev

在本地服务器上测试XMLHttpRequest

来自分类Dev

通过flask在服务器中上传和保存文件出错

来自分类Dev

如何通过异步xmlhttprequest响应设置变量

来自分类Dev

是否可以通过上传/通过上传的文件来攻击服务器?

来自分类Dev

通过 XmlHttpRequest 将数据从 JS 传递到 PHP

来自分类Dev

通过php和html表单上传文件的代码错误

来自分类Dev

公开通过XMLHttpRequest上传到Amazon S3的文件

来自分类Dev

XMLHttpRequest和PHP的问题

来自分类Dev

xmlHttpRequest和操作表?

来自分类Dev

XMLHttpRequest和PHP

来自分类Dev

ajax通过XMLHttpRequest在JavaScript中获取请求(不带表单)

来自分类Dev

通过异步/等待服务器通信?

Related 相关文章

  1. 1

    通过网站上传文件到SFTP服务器

  2. 2

    如何使用FormData和XmlHTTPRequest上传文件?

  3. 3

    如何在服务器上手动取消XMLHttpRequest文件上传(流)

  4. 4

    如何在服务器上手动取消XMLHttpRequest文件上传(流)

  5. 5

    如何通过Ajax下载XMLHTTPRequest加载的文件

  6. 6

    通过XMLHttpRequest()与PHP文件进行AJAX连接

  7. 7

    发送XMLHttpRequest和信息服务器不发送任何确认

  8. 8

    服务器端请求和XmlHTTPRequest(客户端)和安全性

  9. 9

    基本的hello world服务器和Xmlhttprequest客户端-状态始终为0

  10. 10

    具有Node.js的服务器和具有XMLHttpRequest的客户端

  11. 11

    PHP表单文件上传到Mysql和服务器

  12. 12

    通过发布将文件上传到服务器OutOfMemory

  13. 13

    通过网站将文件上传到SFTP服务器

  14. 14

    通过rtmps + java在服务器上上传文件

  15. 15

    通过php在服务器apache上上传文件

  16. 16

    XMLHttpRequest到.js文件

  17. 17

    使用AngularJS和php服务器脚本上传文件

  18. 18

    在本地服务器上测试XMLHttpRequest

  19. 19

    通过flask在服务器中上传和保存文件出错

  20. 20

    如何通过异步xmlhttprequest响应设置变量

  21. 21

    是否可以通过上传/通过上传的文件来攻击服务器?

  22. 22

    通过 XmlHttpRequest 将数据从 JS 传递到 PHP

  23. 23

    通过php和html表单上传文件的代码错误

  24. 24

    公开通过XMLHttpRequest上传到Amazon S3的文件

  25. 25

    XMLHttpRequest和PHP的问题

  26. 26

    xmlHttpRequest和操作表?

  27. 27

    XMLHttpRequest和PHP

  28. 28

    ajax通过XMLHttpRequest在JavaScript中获取请求(不带表单)

  29. 29

    通过异步/等待服务器通信?

热门标签

归档