Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie lade ich Bild-PHP hoch und füge den Pfad in MySQL ein?

In Ihrem Kommentar fragen Sie, wie die Daten in mysql hochgeladen und gespeichert werden sollen. Hier ist es also:

Um die Datei zu erhalten, sollten Sie ein Skript wie dieses in Ihrem HTML-Code haben:

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

Auf POST sollte Ihre PHP-Datei jetzt so aussehen, aber bitte beachten Sie, dass Sie überprüfen müssen, ob die Datei auf Ihrem POST vorhanden ist:

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

  }

Da der Teil "Gespeichert in:" nur der temporäre Pfad ist, sollten Sie mit move_uploaded_file() .Nehmen wir an, der echte/Standardpfad für Ihre Bilder ist in:

$image_dir= '/images/';

Sie müssen die Datei nur folgendermaßen verschieben:

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

Und Ihr vollständiger Pfad zu dem Bild wäre

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

Es gibt mehrere Möglichkeiten, den Pfad zu Ihrer Datenbank zu speichern:

1.:Soll nur den Dateinamen speichern und verketten Sie den Pfad des Bildes in PHP mit $_SERVER['DOCUMENT_ROOT'] und Ihren Standardbildpfad wie:

$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.:Soll den vollständigen Pfad speichern wie:

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

Was ich empfehle, ist dieser Ansatz, bei dem Sie den Teilpfad eingeben (ohne das Root-Verzeichnis), damit Sie später keine Probleme beim Deployment haben:

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

Und stellen Sie sicher, dass die Bilder erfolgreich in dieses Standard-Bildverzeichnis/Pfad hochgeladen wurden .

AKTUALISIEREN

Ich empfehle auch die Verwendung von mysqli_* oder PDO und verwenden Sie prepare() Methode/Funktion zum Verhindern der SQL-Einschleusung.