Update dan Unlink Gambar di PHP


root93.co.id - Mengupdate Data Gambar mungkin tidak akan sama dengan mengupdate data biasa ke database, untuk kebutuhan tetentu mungkin bukan hanya gambar atau file image nya saja yang di update melainkan gambar sebelumnya yang sudah di unggah perlu di unlink atau ikut dihapus supaya tidak menumpuk di folder server, jika memang hany memerlukan satu gambar atau gambar sebelumnya sudah tidak diperlukan atau tidak akan digunakan kembali. Jadi initinya ketika gambar di update datanya, supaya gambar sebelumnya ikut terhapus saat di update, maka kita perlu menggunakan paramater unlink untuk meremove file gambar yang ditaruh didalam folder server, untuk sistem penyimpanan gambarnya saya asumsikan, file gambar ditaruh di folder server sedangkan namanya ditaruh didalam database.

Baca juga :

#1 Buat Database
Pertama buat database dulu buat menampung data – datanya, anggap saja disini data ini untuk menampung data janda. misal id - int (13) nama - varchar (30) foto - varchar (5000)


#2 Koneksi Database
Selanjutnya buatlah sebuah koneksi ke database
<?php
define('DB_SERVER', 'localhost');
define('DB_USERNAME', 'root');
define('DB_PASSWORD', '');
define('DB_NAME', 'data_janda');
$koneksi = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($koneksi === false){
    die("ERROR: Could not connect. " . mysqli_connect_error());
}
?>


#3 File Upload
Buat file upload untuk mengunggah gambar ke folder di server dan nama gambarnya disimpan ke db
<?php
include ('koneksi.php');
$nama_janda = $foto_janda = "";
$nama_janda_err = $foto_janda_err = "";
if($_SERVER["REQUEST_METHOD"] == "POST"){
if(empty(trim($_POST['nama_janda']))){
$nama_janda_err="Nama janda harap diisi";
}else{
$nama_janda=$_POST['nama_janda'];
$nama_janda=mysqli_real_escape_string($koneksi, $nama_janda);
}
//validasi foto
$imgFile = $_FILES['foto_janda']['name'];
$tmp_dir = $_FILES['foto_janda']['tmp_name'];
$imgSize = $_FILES['foto_janda']['size'];

$upload_dir = 'gambar/';
$imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION)); 
$valid_extensions = array('jpeg', 'jpg', 'png', 'gif'); 
$itempic = rand(1000,1000000).".".$imgExt; //rename secara random
//cek data
if (!empty($_FILES["foto_janda"]["tmp_name"])){
//cek ektensi
if(in_array($imgExt, $valid_extensions)){    
//cek besar       
if(!$imgSize < 2000000){
//jika benar upload gambar ke direktori
move_uploaded_file($tmp_dir,$upload_dir.$itempic);
}else{
$foto_janda_err="Maaf file foto terlalu besar"; 
} 
}else{
$foto_janda_err="Maaf Ektensi Foto tidak sesuai";
}
}else{
$foto_janda_err="Maaf Anda belum memilih foto janda";  
}

// Check input errors before inserting in database
    if(empty($nama_janda_err)&& empty($foto_janda_err)){
             
        // Prepare an insert statement
        $sql = "INSERT INTO t_janda (nama_janda, foto) VALUES (?, ?)";
                 if($stmt = mysqli_prepare($koneksi, $sql)){
            // Bind variables to the prepared statement as parameters
            mysqli_stmt_bind_param($stmt, "ss", $param_nama_janda, $param_foto);
            
            // Set parameters
            $param_nama_janda = $nama_janda ;
            $param_foto = $itempic;

            // Attempt to execute the prepared statement
            if(mysqli_stmt_execute($stmt)){
                // Redirect 
               echo "Berhasil nyimpan data <img src='gambar/$param_foto' height='60'>";
                echo "<meta http-equiv=\"refresh\"content=\"2;URL=tampil.php\"/>";
            } else{
                echo "Gagal menyimpan data";
                
            }
        }
         
   // Close statement
   mysqli_stmt_close($stmt);
    }
    mysqli_close($koneksi);
//end method post
}
?>
<html>
<head>
<title>Upload Gambar - ROOT93.CO.ID</title>
</head>
<body>
<div>
<br/>
<br/>
<br/>
<form role="form" method="post" action="<?php echo $_SERVER['PHP_SELF'] ?>" enctype="multipart/form-data">
<input type="text" size="25" required="" maxlength="30" minlength="2" name="nama_janda" placeholder="Masukan nama janda">
<input type="file" name="foto_janda" id="foto_janda"><br/>
<input type="submit" value="Simpan">
</form>
</div>
<p><?php echo $nama_janda_err;?></p>
<p><?php echo $foto_janda_err;?></p>

</body>
</html>


#4 Menampilkan Gambar
Selanjutnya tampilkan gambarnya, contohnya seperti berikut ini
<?php
include('koneksi.php');

$awal=0;
$perintah="SELECT * FROM t_janda";
$query=mysqli_query($koneksi, $perintah);

?>
<html>
<head>
<title>Update Gambar - ROOT93.CO.ID</title>
</head>
<body>
<table width="500" border="1" >
<tbody>
<tr>
<th>No</th>
<th>Nama Janda</th>
<th> Foto</th>
<th>Action</th>
</tr>
<?php //Perulangan 
$no=$awal+1;
while($data=mysqli_fetch_array($query)) {                     
?>
<tr>
    <td><?php echo $no;?></td>
    <td><?php echo $data['nama_janda'];?></td>
    <td><img src="gambar/<?php echo  $data['foto']; ?>" width="60" height="80"/></td>
    <td><a href="update-gambar.php?update=<?php echo $data['id']; ?>">UPDATE</a></td>
</tr>
   
</tr>
 <?php $no+=1;  } ?>
</tbody>
</table>
</body>
</html>



#5 Lakukan Update
Yang terpenting dari pembahasan ini bagaimana teknik update dan unlink gambar sebelumnya, jadi intinya nanti kita dapatkan variabel id nya, lalu di post variabel idnya, ketika di post, Anda bisa query berdasarkan id tersebut, lalu datanya diambil berdasarkan foto selanjutnya tinggal lakukan unlink. Untuk lebih jelasnya ‘perhatikan contoh berikut ini
<?php
include('koneksi.php');
$id = $foto_janda = "";
$id_err = $foto_janda_err = "";
if($_SERVER["REQUEST_METHOD"] == "GET"){
if(empty($_GET["update"])){
echo "id Kosong";
}else{
$query_print=mysqli_prepare($koneksi,"select * from t_janda where id= ?") or die(mysqli_error());
$print=mysqli_real_escape_string($koneksi,$_GET["update"]);
mysqli_stmt_bind_param($query_print,"s",$print);
mysqli_stmt_execute($query_print);
$result=mysqli_stmt_get_result($query_print);
$data_janda=mysqli_fetch_array($result);
//fetch
$foto=$data_janda["foto"];
$id=$data_janda["id"];
} 
mysqli_stmt_close($query_print);
}

?>
<?php
if($_SERVER["REQUEST_METHOD"] == "POST"){
if(empty(trim($_POST['id']))){
$id_err="Id tidak boleh kosong";
}else{
$id=$_POST['id'];
$id=mysqli_real_escape_string($koneksi, $id);
}
//validasi foto
$imgFile = $_FILES['foto_janda']['name'];
$tmp_dir = $_FILES['foto_janda']['tmp_name'];
$imgSize = $_FILES['foto_janda']['size'];

$upload_dir = 'gambar/';
$imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION)); 
$valid_extensions = array('jpeg', 'jpg', 'png', 'gif'); 
$itempic = rand(1000,1000000).".".$imgExt; //rename secara random
//cek data
if (!empty($_FILES["foto_janda"]["tmp_name"])){
//cek ektensi
if(in_array($imgExt, $valid_extensions)){    
//cek besar       
if(!$imgSize < 2000000){
//jika benar upload gambar ke direktori
move_uploaded_file($tmp_dir,$upload_dir.$itempic);
}else{
$foto_janda_err="Maaf file foto terlalu besar"; 
} 
}else{
$foto_janda_err="Maaf Ektensi Foto tidak sesuai";
}
}else{
$foto_janda_err="Maaf Anda belum memilih foto janda";  
}

// Check input errors before inserting in database
if(empty($foto_err)&& empty($id_err)){

//Query berdasarkan id yang di post
 $sql2="SELECT * FROM t_janda where id='$id'";
//query data
$hpsgbr=mysqli_query($koneksi,$sql2);
//fetch data
$jalankan=mysqli_fetch_array($hpsgbr);
//unlink gambar
unlink("gambar/$jalankan[foto]"); 
//end unlink
        // Prepare an insert statement
        $sql = "UPDATE t_janda SET foto=? WHERE id=?";
        
            if($stmt = mysqli_prepare($koneksi, $sql)){
            // Bind variables to the prepared statement as parameters
            mysqli_stmt_bind_param($stmt, "si", $param_foto, $param_id);
            
            // Set parameters   
            $param_foto= $itempic;
            $param_id = $id;
            // Attempt to execute the prepared statement
            if(mysqli_stmt_execute($stmt)){
                // Redirect 
               echo "Berhasil mengupdate gambar <img src='gambar/$param_foto' height='60'>";
          
            } else{
                echo "Gagal menyimpan data";
                
            }
        }
         
   // Close statement
   mysqli_stmt_close($stmt);
    }

//end method post
}
?>
<html>
<head>
<title>Update Gambar - ROOT93.CO.ID</title>
</head>
<body>
<div>
<img width="60" height="80" alt="foto janda" src="gambar/<?php echo $foto; ?>" >
<br/>
<br/>
<br/>
<form role="form" method="post" action="<?php echo htmlspecialchars(basename($_SERVER['REQUEST_URI']));?>" enctype="multipart/form-data">
<input type="hidden" name="id" value="<?php echo $id; ?>">
<input type="file" name="foto_janda" id="foto_janda"><br/>
<input type="submit" value="Simpan">
</form>
</div>
<p><?php echo $id_err;?></p>
<p><?php echo $foto_janda_err;?></p>

</body>
</html>



Jadi begitulah contoh yang bisa diberikan oleh root93.co.id tentang bagaimana Update dan Unlink Gambar di PHP, karena ini hanyalah sekedar contoh Mungkin Anda bisa gunakan cara atau penulisan kode yang lebih pbaik daripada contoh diatas.

Menampilkan gambar
Halaman menampilkan gambar, sekaligus memberi link untuk update ke halaman update gambar
Sumber : root93.co.id

Halaman Update Gambar
Halaman Update Gambar sekaligus nantinya unlink gambar sebelumnya
Sumber : root93.co.id



3 Responses to "Update dan Unlink Gambar di PHP"

  1. Lama gak main di mari, kang ahmad masih setia dengan script PHP yang buat saya mah bikin lieur daa... :D

    ReplyDelete
  2. kang ahmad klo untuk 2 gambar,gambar 1 ter upload gambar 2 gak ke upload, sedangkan database terupdate namanya, masalahnya di mana ya kang?

    ReplyDelete

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin