Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Bagaimana cara mengunggah gambar PHP dan memasukkan jalur di MySQL?

Pada komentar Anda, Anda bertanya bagaimana cara mengunggah dan menyimpan data ke mysql. Jadi ini dia:

Untuk mendapatkan file tersebut, Anda harus memiliki skrip di html Anda seperti ini:

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

Sekarang, pada POST, file PHP Anda akan terlihat seperti ini, tetapi harap perhatikan bahwa Anda harus memeriksa apakah file tersebut ada di POST Anda:

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

  }

Karena bagian "Tersimpan di:" hanyalah jalur sementara, Anda harus pindah ke jalur gambar 'asli' menggunakan move_uploaded_file() . Katakanlah jalur asli/default untuk gambar Anda ada di:

$image_dir= '/images/';

Anda hanya perlu memindahkan file menggunakan ini:

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

Dan jalur lengkap Anda ke gambar adalah

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

Ada beberapa cara untuk menyimpan jalur ke database Anda:

1:Apakah untuk menyimpan hanya nama file dan gabungkan jalur gambar dalam PHP menggunakan $_SERVER['DOCUMENT_ROOT'] dan jalur gambar default Anda seperti:

$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:Adalah untuk menyimpan jalur lengkap seperti:

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

Yang saya sarankan adalah pendekatan ini di mana Anda akan memasukkan jalur parsial (tanpa dir root) agar nantinya anda tidak kesulitan dalam men-deploynya:

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

Dan pastikan gambar berhasil diunggah ke dir/jalur gambar default .

PERBARUI

Saya juga menyarankan Anda menggunakan mysqli_* atau PDO dan gunakan prepare() metode /fungsi untuk mencegah injeksi sql.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. JSON_KEYS() – Mengembalikan Kunci dari Objek JSON di MySQL

  2. Hibernate OneToOne pemuatan lambat dan cascading

  3. Data MySQL - Cara terbaik untuk mengimplementasikan paging?

  4. Paginasi dalam PDO PHP

  5. Apa perbedaan antara rangkaian karakter utf8mb4 dan utf8 di MySQL?