Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to keep the previous uploaded image (in db) after submitting a form without selecting a new image to be uploaded

I have a simple form for creating an article: Title,image,category,body , etc.. My problem is with the image input.

Selecting a new one and submitting everything works fine:

  • the image is being uploaded to the server
  • the title of the image is being saved to db
  • and i can print it in the article.

By editing the whole form, filling all fields but leaving the image field as it is, and finally submitting, the image field value in db is changing to nothing.

How can i configure the php file, so every time the user submits the form without selecting an image (if there was an image pre uploaded in that article ) keep as submitted the previous image (from db) instead of nothing.?


If these informations can be of any help:

I can print the image like this : <?php echo '<img src="'.$results['article']->img.'" width="100px">'; ?>

Simple input field for image:

<input type="file" name="fileToUpload" id="fileToUpload"  value="<?php echo $results['article']->img ?>" />
like image 257
Pantelis Avatar asked Apr 07 '15 08:04

Pantelis


2 Answers

What about something like this?

if(!empty($_FILES['fileToUpload']['name'])) //new image uploaded
{
   //process your image and data
   $sql = "UPDATE table SET name=?, image=?,... WHERE id = ?";//save to DB with new image name
}
else // no image uploaded
{
   // save data, but no change the image column in MYSQL, so it will stay the same value
   $sql = "UPDATE table SET name=?,... WHERE id = ?";//save to DB but no change image column
}
//process SQL query in $sql
like image 59
zdeniiik Avatar answered Nov 13 '22 09:11

zdeniiik


Make a if clause that checks if fileupload input is empty or not. If it is empty do not execute query.

Use input type="file" without attribute value.

<input type="file" name="fileToUpload" id="fileToUpload" />

Here is example for if clause

if(!empty($_FILES['fileToUpload']['name'])) {
        $origFile = $_FILES['fileToUpload']['name'];
        $tempFile = $_FILES['fileToUpload']['tmp_name'];
        $sizeFile = $_FILES['fileToUpload']['size'];

        /* UPLOAD CODE GOES HERE */
    }
like image 41
Plamen Nikolov Avatar answered Nov 13 '22 10:11

Plamen Nikolov