2012-04-22 72 views
1

我想用PHP上传文件。我写了无法在PHP中进行文件上传

<form target="_self" enctype="multipart/form-data"> 
<input type="file" name="file" id="file" /> 
<input name="submit" type="submit" value="submit" /> 
</form> 
<?php 

if ($_FILES["file"]["error"] > 0) 
    { 
    echo "Error: " . $_FILES["file"]["error"] . "<br />"; 
    } 
else 
    { 
    echo "Upload: " . $_FILES["file"]["name"] . "<br />"; 
    echo "Type: " . $_FILES["file"]["type"] . "<br />"; 
    echo "Size: " . ($_FILES["file"]["size"]/1024) . " Kb<br />"; 
    echo "Stored in: " . $_FILES["file"]["tmp_name"]; 
    } 

?> 

但它不工作。文件对我来说是不可见的,他们要去哪里?

回答

4

您是从一个工作脚本

很长的路要走,您可以尝试

<?php 
$output = array(); 
$errors = array(); 
$savePath = "uploaded"; // PATH to upload images 
$allowedExt = array (
     "png", 
     "jpg" 
); 
if (isset ($_FILES ['file']) && $_FILES ["file"] ["error"] == UPLOAD_ERR_OK) { 

    $fileName = $_FILES ['file'] ['name']; 
    $fileSize = $_FILES ['file'] ['size']; 
    $fileTemp = $_FILES ['file'] ['tmp_name']; 
    $fileType = $_FILES["file"]["type"] ; 
    $fileExt = pathinfo ($fileName, PATHINFO_EXTENSION); 
    $fileExt = strtolower ($fileExt); 

    //var_dump($fileExt); 

    if (!in_array ($fileExt, $allowedExt)) { 
     $errors [] = "Invalid File Extention"; 
    } 

    if ($fileSize > 800*1024) { 
     $errors [] = "File Too large"; 
    } 

    if (! is_writable ($savePath)) { 
     $errors [] = "File Destination not writeable"; 
    } 

    $fileDst = $savePath . DIRECTORY_SEPARATOR . $fileName; 
    $filePrifix = basename ($fileName, "." . $fileExt); 
    $i = 0; 
    while (file_exists ($fileDst)) { 
     $i ++; 
     $fileDst = $savePath . DIRECTORY_SEPARATOR . $filePrifix . "_" . $i . "." . $fileExt; 

    } 
    if (count ($errors) == 0) { 
     if (@move_uploaded_file ($fileTemp, $fileDst)) { 
      $output['STATUS'] = "OK"; 
      $output['TYPE'] = $fileType; 
      $output['Size'] = $fileSize; 
      $output['Destination'] = $fileDst; 
     } else { 
      $errors [] = "Error Saving File"; 
     } 

    } 


    if(count($errors) > 0) 
    { 
     echo "<h2>Upload Error</h2>" ; 

     foreach ($errors as $error) 
     { 
      echo $error , "<br/>" ; 

     } 
    } 
    else 
    { 
     echo "<h2>File Uploaded</h2>" ; 
     foreach ($output as $key => $value) 
     { 
      echo $key , ":" , $value , "<br/>" ; 
     } 

    } 
} 

?> 
<br/> 
<br /> 
<form method="post" target="_self" enctype="multipart/form-data"> 
    <input type="file" name="file" id="file" /> <input name="submit" 
     type="submit" value="submit" /> 
</form> 
+0

这是不安全的,因为我的网站被黑了。 – 2012-09-27 10:49:14

+0

@Christian Nikkanen这个上传不是为了检测假图片......你必须真的是忘恩负义的人 – Baba 2012-09-27 10:50:52

+0

这将是很好的说,它可以很容易地被黑客入侵。 – 2012-09-27 11:11:39

3

你的代码甚至没有接近工作,因为你实际上没有通过PHP来上传任何文件。我建议从PHP file upload tutorialmore)开始并重试。如果您的新代码有任何问题,请寻求帮助,并向我们展示您遇到问题的代码。

+0

tizag的代码是不工作的文件上传。 – Thompson 2012-04-22 17:44:19

0

您需要使用POST方法才能使文件上传正常工作。
因此,只需将method="post"属性添加到form标记即可完成。