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

Hvordan uploader man PHP-billede og indsætter sti i MySQL?

På din kommentar spørger du, hvordan du uploader og gemmer dataene til mysql. Så her er det:

For at få filen skal du have et script i din html som dette:

<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, skulle din PHP-fil se sådan ud, men vær opmærksom på, at du skal tjekke, om filen findes 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"];

  }

Da "Stored in:"-delen kun er den midlertidige sti, bør du flytte til din 'rigtige' billedsti ved hjælp af move_uploaded_file() . Lad os sige, at den rigtige/standardstien til dine billeder er i:

$image_dir= '/images/';

Du skal blot flytte filen ved at bruge denne:

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

Og din fulde vej til billedet ville være

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

Der er flere måder at gemme stien til din database på:

1.:Er kun at gemme filnavnet og sammenkæde stien til billedet i PHP ved hjælp af $_SERVER['DOCUMENT_ROOT'] og din standardbilledsti 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.:Er at gemme den fulde sti som:

$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, jeg anbefaler, er denne tilgang, hvor du vil indtaste den delvise sti (uden root dir), så du senere ikke har problemer med at implementere 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]')";

Og sørg for, at billederne er uploadet til den standard billeddir/sti .

OPDATERING

Jeg anbefaler også, at du bruger mysqli_* eller PDO og brug prepare() metode /funktion til at forhindre sql-injektion.



  1. 2 måder at liste tabellerne i en SQLite-database

  2. join på to fremmednøgler fra samme tabel i SQL

  3. Hvordan opretter man en Postgres-tabel med en unik kombineret primærnøgle?

  4. Hvordan kan jeg lave en tabel i MySQL kaldet ordre?