2015-10-23 33 views
0

我已经尝试了最近3个小时的所有建议解决方案,但都没有为我工作。请记住,我对ajax非常陌生。如何使用Ajax将文件上传到php脚本使用XAMPP

这里是我的Ajax代码:

var formData = new FormData(); 
formData.append('file', $('#commercialAnimation')[0].files[0]); 


$.ajax({ 

url : 'includes/upload.php', 
    type : 'POST', 
    data : formData, 
    processData: false, // tell jQuery not to process the data 
    contentType: false, // tell jQuery not to set contentType 
    success : function(data) { 
     console.log(data); 
     alert(data); 
    } 
}); 

这里是片形式的(这是其默认禁用最后一个表单属性):

<label id="uploadAnimation">Upload your file:</label> 
<input type="file" id="myfile" disabled> 

这里是PHP类应该检索此文件:

include 'db_connector.php'; 
$fileName = $_FILES['file']['name']; 
$fileType = $_FILES['file']['type']; 
$fileError = $_FILES['file']['error']; 
$fileContent = file_get_contents($_FILES['file']['tmp_name']); 

if($fileError == UPLOAD_ERR_OK){ 
//file uploaded 
}else{ 
//error while uploading 

    echo json_encode(array(
      'error' => true, 
      'message' => $message 
     )); 
} 

当我尝试将消息记录到单独的文件php代码似乎工作,但我可以找不到任何xampp文件夹中的文件。 此外,来自ajax的alert(data);不显示任何值。

+0

你虽然看到的console.log(数据)输出成功的回调? – AdamJeffers

+0

我看到弹出框,但它是空的 – Lenny

+0

'$ fileName = $ _FILES ['file'] ['name'];''和'$ fileType = $ _FILES ['file'] ['type'];'存储正确的文件名并键入 – Lenny

回答

2

你应该通过调用move_uploaded_file首先将文件移动到某个文件夹:

if ($fileError == UPLOAD_ERR_OK) { 
     $tmp_name = $_FILES['file']['tmp_name']; 
     $name = $_FILES['file']['name']; 
     move_uploaded_file($tmp_name, "$your_uploads_dir/$name"); 
    } 
+0

我得到这个错误:'警告:move_uploaded_file(tmp/home-cat.jpg):无法打开流:没有这样的文件或目录在D:\ xampp \ htdocs \ biz \ pages \ includes \ upload.php线

警告:move_uploaded_file()以:无法移动 'd:\ XAMPP \ TMP \ php54A.tmp' 到 'TMP /家庭cat.jpg' 在d:\ XAMPP \ htdocs \ biz \ pages \ includes \ upload.php on line
'第15行是:'move_uploaded_file($ tmp_name,“tmp/$ name”);' – Lenny

+0

那是因为'tmp/home-cat.jpg'不是有效的目录。您需要指定从驱动器到服务器可访问目录的完整路径。在站点的文档根目录中创建一个文件夹并指向它。像D:\ xampp \ htdocs \ biz \ uploads \ home-cat.jpg –

+0

它的工作原理!非常感谢!你是最好的安东! – Lenny