2012-04-22 22 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

私のサイトがこれでハックしたので、使用するのは安全ではありません。 –

+0

@Christian Nikkanenこれは偽の画像を検出するためではなくアップロード用です...あなたは本当に恩知らずの人でなければなりません – Baba

+0

非常に簡単にハックすることができます。 –

3

実際にはPHP経由でファイルをアップロードしていないため、あなたのコードは動作していません。 PHP file upload tutorialmore)で始まり、もう一度試してみることをおすすめします。新しいコードに問題がある場合は、ヘルプを求めて問題のあるコードを表示してください。

+0

tizagのコードは、ファイルアップロードのために働いていない試みることができる作業スクリプト

から長い道のりです。 – Thompson

0

ファイルのアップロードを有効にするには、POSTメソッドを使用する必要があります。
method="post"属性をformタグに追加するだけです。

関連する問題