AJAX上传文件不起作用

AJAX uploading files not working

本文关键字:不起作用 文件 AJAX      更新时间:2023-09-26

我想使用ajax在浏览器上上传文本文件,但我不知道如何做到这一点。文件未上载,var_dump($files)回显数组(0)。

HTML:

<form id="uploadsql" action="upload.js" method="post" enctype="multipart/form-data">
    <input id="uploadFile" type="text" disabled="disabled" placeholder="Choose File" />
    <div  class="fileUpload btn btn-primary">
        <span>Upload</span>
        <input id="uploadBtn" name="file" type="file" class="upload"required />
    </div>
    <div class="fileUpload btn btn-primary">
        <span>Submit</span>
    <input type = "submit" id="uploadBtn" class="upload" /></div>
    </form>
    <h4 id='loading' >Loading...</h4>
    <div id="message"></div>
    <script type="text/javascript">  
            document.getElementById("uploadBtn").onchange = function () {  
                document.getElementById("uploadFile").value = this.value;
            };
    </script>

JS:

$(document).ready(function (e) {
$("#uploadsql").on('submit',(function(e) {
e.preventDefault();
$("#message").empty();
$('#loading').show();
$.ajax({
url: "upload.php", // Url to which the request is send
type: "POST",             // Type of request to be send, called as method
cache: false,             // To unable request pages to be cached
success: function(data)   // A function to be called if request succeeds
{
$('#loading').hide();
$("#message").html(data);
}
});
}));

});

PHP:

<?php
set_time_limit(0);
header('content-type: text/html; charset=utf-8');
header("access-control-allow-origin: *");
include 'connect.php';

if(isset($_FILES["uploadBtn"]["type"]))
{
echo 'yes';
} else {
    $files = $_FILES;
    var_dump ($files);
}

?>

我在这里做错了什么?提前感谢!

通过查看您的ajax调用,您没有将"data"属性包括到ajax对象中。但我建议你看看这个答案jQuery AJAX文件上传PHP