0

こんにちは、私は Ajax と PHP を使用してファイルをアップロードしようとしています。チュートリアルですべてのことを行ったところ、このファイルに到達しました: upload.js:

var handleUpload = function (event){
event.preventDefault();
event.stopPropagation();

var fileInput= document.getElementById('File');

var data= new FormData();
for(var i=0;i<fileInput.files.length;i++){
    data.append('file[]',fileInput.files[i]);
}
var request= new XMLHttpRequest();
request.addEventListener('progress',function(event){

    if(event.lengthComputable){
        alert("caesar");
    var percent = event.loaded / event.total;
    var progress = document.getElementById('upload_progress');

  while(progress.hasChildNodes()){
      progress.removeChild(progress.firstChild)
  }
  progress.appendChild(document.createTextNode(Math.round(percent * 100)+ ' %'));
   } 
});
request.upload.addEventListener('load',function(event){
  document.getElementById('upload_progress').style.display='none';  
});

request.upload.addEventListener('error',function(event){
  alert('Upload Filed');  
});

request.open('POST','upload.php');
request.setRequestHeader("Cache-Control","no-cache")
document.getElementById('upload_progress').style.display='block';  
alert(request)
request.send();
}

window.addEventListener('load',function(event){
var submit = document.getElementById("Submit");    
submit.addEventListener("click",handleUpload);
});   

そしてupload.php:

 <?php 
 if(!empty($_FILES['file'])){
 foreach($_FILES['file']['name'] as $key => $name){
    if($_FILES['file']['error'][$key] == 0 && move_uploaded_file($_FILES['file']['tmp_name'][$key],'./'.$name)){
       $uploaded[]=$name; 
    }
 }

 }
 ?>
 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4    /strict.dtd">
 <head>
 <meta content="text/html; charset=ISO-8859-1" http-equiv="content-type"/>
 <title>Upload &amp; Ajax</title>
 </head>
 <script type="text/javascript" src="upload.js"></script>
 <style type="text/css">
 #upload_progress { display: none;}
 </style>
 <body>
 <div id="uploaded">
 <?php
 if(!empty($uploaded)){
 foreach($uploaded as $name){
    echo "<div><a href='./".$name."'>".$name."</a></div>";
 }
 }
 ?>
 </div>
 <div id="upload_progress"></div>
 <div>
 <form action="<?php echo $_SERVER["PHP_SELF"];?>" method="post" enctype="multipart/form-data">
 <div>
 <input type="file" id="File" name="file[]" multiple="multiple" />
 <input type="submit" id="Submit" value="upload"/>
 </div>
 </form>
 </div>
 </body>
 </html>

アップロードをクリックしたところ、100% と表示されました。フォルダに移動しましたが、ファイルが見つかりませんでした。

4

2 に答える 2

0

ファイルをアップロードするときは常に、次のことに注意する必要があります。

  1. ファイルをアップロードしたいフォルダが存在する場合。
  2. そのフォルダに権限が付与されている場合。
  3. アップロードされているファイルの種類が許可されている場合。
  4. ファイルのサイズ
  5. フォームには enctype="multipart/form-data" が含まれている必要があります
于 2013-09-20T19:39:58.130 に答える
0

最初に、派手な JS なしで PHP ファイルが機能するかどうかを確認します。フォーム POST を介して通常のファイル アップロードを機能させます。アップロードされたファイルは、現在のフォルダー、つまり'./'.$name. ファイルをアップロードする予定の場所にフォルダーを変更します。

HTML/PHP を完璧にしたら、JS の修正に取り掛かります。

于 2013-09-20T19:35:57.790 に答える