Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment télécharger une image PHP et insérer un chemin dans MySQL ?

Dans votre commentaire, vous demandez comment télécharger et stocker les données sur mysql. Alors voilà :

Pour obtenir le fichier, vous devriez avoir un script dans votre html comme celui-ci :

<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>

Maintenant, sur POST, votre fichier PHP devrait ressembler à ceci mais veuillez noter que vous devez vérifier si le fichier existe sur votre 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"];

  }

Étant donné que la partie "Stocké dans :" n'est qu'un chemin temporaire, vous devez vous déplacer vers votre chemin d'image "réel" en utilisant move_uploaded_file() .Disons que le chemin réel/par défaut pour vos images est dans :

$image_dir= '/images/';

Il vous suffit de déplacer le fichier en utilisant ceci :

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

Et votre chemin complet vers l'image serait

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

Il existe plusieurs façons de stocker le chemin d'accès à votre base de données :

1er  :ne stocker que le nom de fichier et concaténez le chemin de l'image en PHP en utilisant $_SERVER['DOCUMENT_ROOT'] et votre chemin d'image par défaut comme :

$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ème :Est de stocker le chemin complet comme :

$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]')";

Ce que je recommande, c'est cette approche dans laquelle vous saisirez le chemin partiel (sans le répertoire racine) afin que plus tard vous n'ayez pas de problème pour le déployer :

$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]')";

Et assurez-vous que les images sont téléchargées avec succès dans ce répertoire/chemin d'image par défaut .

MISE À JOUR

Je vous recommande également d'utiliser mysqli_* ou PDO et utilisez prepare() méthode/fonction pour empêcher l'injection sql.