Mysql
 sql >> Database >  >> RDS >> Mysql

Come caricare l'immagine PHP e inserire il percorso in MySQL?

Sul tuo commento chiedi come caricare e memorizzare i dati su mysql. Quindi eccolo qui:

Per ottenere il file, dovresti avere uno script nel tuo html come questo:

<html>
<body>

     <form action="upload_file.php" method="post" enctype="multipart/form-data">
        <label for="file">Filename:</label>
        <input type="file" name="file" id="file"><br>
        <input type="submit" name="submit" value="Submit">
     </form>

</body>
</html>

Ora, su POST, il tuo file PHP dovrebbe assomigliare a questo, ma tieni presente che devi controllare se il file esiste sul tuo POST:

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"];

  }

Poiché la parte "Memorizzata in:" è solo il percorso temporaneo, dovresti passare al percorso dell'immagine "reale" utilizzando sposta_file_caricato() .Diciamo che il percorso reale/predefinito per le tue immagini è in:

$image_dir= '/images/';

Devi solo spostare il file usando questo:

move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $image_dir. $_FILES['uploaded_file']['name']);

E il tuo percorso completo verso l'immagine sarebbe

$image = $final_save_dir . $_FILES['uploaded_file']['name'];

Esistono diversi modi per memorizzare il percorso del database:

1°:è memorizzare solo il nome file e concatena il percorso dell'immagine in PHP usando $_SERVER['DOCUMENT_ROOT'] e il percorso dell'immagine predefinito come:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( '$image', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

2°:è memorizzare il percorso completo come:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( '".$_SERVER['DOCUMENT_ROOT']."\\images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

Quello che consiglio è questo approccio in cui inserirai il percorso parziale (senza la directory di root) in modo da non avere problemi a distribuirla in seguito:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( 'images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

E assicurati che le immagini siano state caricate correttamente in quella dir/percorso immagine predefinito .

AGGIORNAMENTO

Ti consiglio anche di usare mysqli_* o PDO e usa prepare() metodo /funzione per impedire l'iniezione di sql.