sql >> Database >  >> RDS >> Mysql

Hoe afbeelding PHP uploaden en pad invoegen in MySQL?

Bij uw opmerking vraagt ​​u hoe u de gegevens kunt uploaden en opslaan naar mysql. Dus hier is het:

Om het bestand te krijgen, moet je een script in je html hebben zoals dit:

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

Nu, op POST, zou je PHP-bestand er als volgt uit moeten zien, maar houd er rekening mee dat je moet controleren of het bestand bestaat op je 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"];

  }

Aangezien het gedeelte "Opgeslagen in:" slechts het tijdelijke pad is, moet u naar uw 'echte' afbeeldingspad gaan met move_uploaded_file() .Stel dat het echte/standaardpad voor uw afbeeldingen zich in:

. bevindt
$image_dir= '/images/';

Je hoeft het bestand alleen maar als volgt te verplaatsen:

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

En je volledige pad naar de afbeelding zou zijn

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

Er zijn verschillende manieren om het pad naar uw database op te slaan:

1e:Is om alleen de bestandsnaam . op te slaan en voeg het pad van de afbeelding in PHP samen met $_SERVER['DOCUMENT_ROOT'] en uw standaard afbeeldingspad zoals:

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

2e:Is om het volledige pad . op te slaan zoals:

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

Wat ik aanbeveel is deze aanpak waarbij je het gedeeltelijke pad . invoert (zonder de hoofdmap) zodat je later geen problemen hebt met het implementeren ervan:

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

En zorg ervoor dat de afbeeldingen met succes worden geüpload naar die standaard afbeeldingsmap/pad .

UPDATE

Ik raad je ook aan om mysqli_* . te gebruiken of PDO en gebruik prepare() methode / functie om sql-injectie te voorkomen.



  1. Laravel Eenvoudige maandselectie

  2. Probleem met Java-programma en mySQL-verbinding:geen geschikt stuurprogramma gevonden

  3. ORDER BY en GROUP BY samen gebruiken

  4. Een standaard MySQL/MariaDB-gegevensmap in Linux wijzigen