sql >> Databasteknik >  >> RDS >> Mysql

Hur laddar man upp PHP-bild och infogar sökväg i MySQL?

På din kommentar frågar du hur du laddar upp och lagrar data till mysql. Så här är den:

För att få filen bör du ha ett skript i din html så här:

<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, på POST, bör din PHP-fil se ut så här, men tänk på att du måste kontrollera om filen finns på din 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"];

  }

Eftersom "Lagrad i:"-delen bara är den tillfälliga sökvägen bör du flytta till din "riktiga" bildsökväg med move_uploaded_file() . Låt säga att den verkliga/standardsökvägen för dina bilder finns i:

$image_dir= '/images/';

Du behöver bara flytta filen med detta:

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

Och din fullständiga väg till bilden skulle vara

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

Det finns flera sätt att lagra sökvägen till din databas:

1:a:Är att bara lagra filnamnet och sammanfoga bildens sökväg i PHP med $_SERVER['DOCUMENT_ROOT'] och din standardbildsökväg som:

$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:a:Är att lagra den fullständiga sökvägen gillar:

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

Det jag rekommenderar är detta tillvägagångssätt där du kommer att ange delvägen (utan root dir) så att du senare inte har problem med att distribuera den:

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

Och se till att bilderna laddas upp till den standardbilden dir/sökväg .

UPPDATERA

Jag rekommenderar också att du använder mysqli_* eller PDO och använd prepare() metod /funktion för att förhindra sql-injektion.



  1. SQL Server Internals:Plan Caching Pt. I – Återanvändning av planer

  2. Finns det någon anledning att oroa sig för kolumnordningen i en tabell?

  3. Kalendertabell för Data Warehouse

  4. Mysql-funktion som returnerar ett värde från en fråga