获取ajax POST php

时间:2012-08-08 02:50:47

标签: php ajax

我正在尝试让ajax文件上传器工作,并将一些额外的表单数据传递给php。 php脚本能够获得$ _FILES ['fileToUpload'],但我得到$ _POST [“fname”]的未定义索引;

PHP

if(isset($_FILES['fileToUpload'])){

$fname = $_POST["fname"];

$name = htmlentities($_FILES['fileToUpload']['name']);
}

JAVASCRIPT

var fd = new FormData();
fd.append("fileToUpload", document.getElementById('fileToUpload').files[0]);
var xhr = new XMLHttpRequest();
xhr.upload.addEventListener("progress", uploadProgress, false);
xhr.addEventListener("load", uploadComplete, false);
xhr.addEventListener("error", uploadFailed, false);
xhr.addEventListener("abort", uploadCanceled, false);
xhr.open("POST", "uploader.php");
xhr.send(fd);

HTML

<form id="form1" name="form1" enctype="multipart/form-data">
                <div id="user">
                    <input type="text" id="fname" name="fname" />
                </div>
                <div id="fileInfo">
                    <div id="fileName"></div>
                    <div id="fileSize"></div>
                    <div id="fileType"></div>
                </div>
                <div class="row"></div>
                <div class="row">
                    <input type="file" name="fileToUpload" id="fileToUpload" onchange="fileSelected();"/>
                </div>
                <div class="row">
                    <input type="button" onclick="uploadFile()" value="Upload" />

1 个答案:

答案 0 :(得分:1)

因为您使用ajax发送帖子,所以您需要执行类似

的操作
fd.append("fname", document.getElementById('fname').value);

否则,没有什么可以告诉'onclick'发送你的fname输入字段。

只有使用提交按钮才会发送输入字段。