2017-02-20 3 views
0

Я попытался создать сценарий для загрузки нескольких фотографий, переименования фотографии и добавления записи в базу данных. Запись имени файла базы данных верна, однако имя загружаемого изображения усугубляет имя jpg.Проблема с именованием путей к файлу

ie. запись базы данных правильно именования файлов: photo_1, photo_2, Фотография_3

Файлы загружаются с именем неправильно: photo_1.jpg, photo_1.jpgphoto_2.jpg, photo_1.jpgphoto_2.jpgphoto_3.jpg

Не знаете, как решить это, поскольку моя запись в базе данных верна.

<?php 
if (isset($_POST['submit'])) { 
    $j = 0; //Variable for indexing uploaded image 
    $image_post_id = $_POST["image_post_id"]; 

    $target_path = "uploads/"; //Declaring Path for uploaded images 
    for ($i = 0; $i < count($_FILES['file']['name']); $i++) {//loop to get individual element from the array 




     $validextensions = array("jpeg", "jpg", "png", "JPG", "PNG", "JPEG"); //Extensions which are allowed 
     $ext = explode('.', basename($_FILES['file']['name'][$i]));//explode file name from dot(.) 

     $file_extension = end($ext); //store extensions in the variable 





     //MYSQL Handling 

      mysql_query("INSERT INTO post_images(`image_filename`, `image_post_id`) VALUES('0', '".addslashes($image_post_id)."')"); 
          $new_id = mysql_insert_id(); 

          $target_path = $target_path . "post_". $new_id . "." . strtolower($ext[count($ext) - 1]);//set the target path with a new name of image 
          mysql_query("UPDATE post_images SET image_filename='post_".addslashes($new_id).".".strtolower($ext[count($ext) - 1])."' WHERE image_id='".addslashes($new_id)."'"); 












     $j = $j + 1;//increment the number of uploaded images according to the files in array  

     if (($_FILES["file"]["size"][$i] < 1000000) //Approx. 100kb files can be uploaded. 
       && in_array($file_extension, $validextensions)) { 
      if (move_uploaded_file($_FILES['file']['tmp_name'][$i], $target_path)) {//if file moved to uploads folder 
       echo $j. ').<span id="noerror">Image uploaded successfully!.</span><br/><br/>'; 
      } else {//if file was not moved. 
       echo $j. ').<span id="error">please try again!.</span><br/><br/>'; 
      } 
     } else {//if file size and file type was incorrect. 
      echo $j. ').<span id="error">***Invalid file Size or Type***</span><br/><br/>'; 
     } 
    } 
} 
?> 
+0

Стоп, что вы делаете, сейчас. Вы используете устаревший, неподдерживаемый и небезопасный API баз данных. Альтернативы, такие как PDO, доступны уже более десятилетия. См. Http://stackoverflow.com/questions/12859942/why-shouldnt-i-use-mysql-functions-in-php – miken32

+0

Чтобы помочь людям ответить на ваш вопрос, могу ли я предложить две вещи: 1- Отформатировать код, который вы публикуете, быть более читабельным. 2- Расскажите, что вы ожидаете в результате (окончательное имя, которое должно быть получено, даже если я могу получить его из вашего кода, всегда хорошо быть явным). –

ответ

1

Ваша проблема с этой линией в вашей для цикла:

$target_path = $target_path . "post_". $new_id . "." . strtolower($ext[count($ext) - 1]); 

Этот код в основном говорит «Append новое имя файла к предыдущему значению», которое, очевидно, не то, что вы хотите.

Чтобы исправить, просто удалите $target_path на правой части =:

$target_path = "post_". $new_id . "." . strtolower($ext[count($ext) - 1]); 
+0

спасибо! Работал, как шарм, очень ценился. Я не очень разбираюсь в php. Думаю, мне придется выяснить, как переключиться на mysqli. – Jason

+0

Добро пожаловать ..! Примите ответ :-) – BizzyBob

Смежные вопросы