Tutorial PHP : Menghapus Foto yang di Encode Base64
Melanjutkan tutorial sebelumnya tentang bagaimana mengenkripsi/encode foto menggunakan base64 maka dalam tutorial ini saya akan memberikan bagaimanacara menghapus foto yang disimpan dengan encode base64.
Dalam contoh kasus ini, tentu gambar/foto yang anda encode menggunakan base64 tidak bisa dihapus begitu saja pada server melalui kombinasi query berdasarkan nama file yang terencode, jika anda tidak percaya silahkan coba saja menggunakan parameter seperti misal unlik.
Untuk menghapus foto yang diencode menggunakan base64 ini sebernernya saya lebih tertarik untuk menggunakan ‘jalan mudah’ dibandingkan harus melakukan metode decode atau semacanya. Dengan cara menyimpan nama file gambar/foto yang tanpa enkripsi/encode. Dan sebenarnya sampai kita sudah menemukan solusi termudah.
Sebelumnya silahkan baca dulu : Tutorial PHP : Upload Gambar dengan Enkripsi Base64
Selanjutnya kita buat sebuah fungsi untuk meng-get data gambar berdasarkan id datanya, tujuannya tentu untuk menggunakannya pada halaman delete dan memanggil file foto/gambar tanpa encode untuk dihapus. Jadi ada dua fungsi yang perlu ditambakan ke script sebelumnya yaitu fungsi delete data yang berada di databasenya dan fungsi untuk melakukan get data sebelumnya data foto di unlink
Berikut fungsi yang bisa Anda tambahkan
public function getImage_delete($data)
{
try
{
$sql = "DELETE FROM foto WHERE id=:id";
$stmt = $this->koneksi->prepare($sql);
$stmt->execute(array(":id"=>$data));
return true;
}
catch(PDOException $e)
{
return false;
}
}
public function getImage_data($data)
{
try
{
$sql = "SELECT id, name, image FROM foto WHERE id=:id";
$stmt = $this->koneksi->prepare($sql);
$stmt->bindParam(":id", $data);
$stmt->execute();
$stmt->bindColumn(1, $this->id);
$stmt->bindColumn(2, $this->name);
$stmt->bindColumn(3, $this->image);
$stmt->fetch(PDO::FETCH_ASSOC);
if($stmt->rowCount()==1)
{
return true;
}
}
catch(PDOException $e)
{
return false;
}
}
Buat sebuah halaman untuk melakukan proses data dan unlink. Pertama data foto di unlink terlebih dahulu lalu kemudian jika berhasil lakukan delete data yang berada dalam database. Anda bisa membuatnya seperti berikut :
<?php
require_once('db.php');
require_once('class.upload.php');
$obj = new upload;
if(!$obj->getImage_data($_GET['id'])){
echo "Data tidak ditemukan";
}
?>
<?php
if(isset($_POST['delete']))
{
if(unlink('image/'.$obj->name)):
if($obj->getImage_delete($obj->id)):
echo "Gambar berhasil dihapus";
else:
echo "Gambar gagal dihapus";
endif;
else:
echo "Gambar pada server gagal dihapus";
endif;
}
?>
<!DOCTYPE html>
<html>
<head>
<title>Delete Foto Base64</title>
</head>
<body>
<form action="" method="post">
<label>Yakin ingin menghapus data ini ?</label>
<input type="submit" name="delete" value="delete">
</form>
</body>
</html>
Pada halaman index atau halaman upload, Anda bisa menambhakan parameter id untuk proses get data yang dibutuhkan oleh halaman delete, sehingga nanti Anda bisa membuatnya seperti berikut ini :
<?php
require_once('db.php');
require_once('class.upload.php');
$obj = new upload;
$error = array();
if($_SERVER['REQUEST_METHOD']=='POST')
{
$obj->getImage2('image');
if(!$obj->fileExtension($obj->file_extension, $obj->file_valid)):
array_push($error, "Maaf ektensi file salah");
elseif($obj->fileSize($obj->file_size)):
array_push($error,"Maaf file terlalu besar");
endif;
/* With no rename new image
if(count($error)==0):
if(move_uploaded_file($obj->file_tmp, $obj->file_target)):
if($obj->insertImage($obj->file_name, $obj->image)):
echo "Gambar berhasil di upload";
else:
echo "Gambar gagal di upload";
endif;
else:
echo "Gagal mengunggah gambar";
endif;
endif;
*/
if(count($error)==0):
if(move_uploaded_file($obj->file_tmp,$obj->file_dir.$obj->file_item)):
if($obj->insertImage($obj->file_item, $obj->image)):
echo "Gambar berhasil di upload";
else:
echo "Gambar gagal di upload";
endif;
else:
echo "Gagal mengunggah gambar";
endif;
endif;
}
$obj->getError($error);
?>
<!DOCTYPE html>
<html>
<head>
<title>Upload</title>
</head>
<body>
<form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" enctype="multipart/form-data">
<input type="file" name="image">
<input type="submit" name="upload" value="upload">
</form>
<table class="table table-bordered" border="1">
<tr>
<th>NO</th>
<th>FOTO DB</th>
<th>FOTO BASE64</th>
<th>AKSI</th>
</tr>
<?php
$data=$obj->imageFetch();
$no=1;
while($row=$data->fetch(PDO::FETCH_ASSOC)){
?>
<tr>
<td><?php echo $no; ?></td>
<td><img src="image/<?php echo $row['name']; ?>" width="100px"></td>
<td><img src="<?php echo $row['image']; ?>" width="100px"></td>
<td><a href="delete.php?id=<?php echo $row['id'];?>"> Hapus</a></td>
</tr>
<?php $no+=1; } $data->closeCursor();?>
</table>
</body>
</html>
Kesimpulan
- Buat sebuah desain database/tabel dengan dua jenis tipe kolom foto yang terencode dan yang tidak
- Saat akan menambahkan parameter unlik, Anda tinggal memasukan nama file foto tanpa encode kedalamnya
- Jadi saat menampilkan gambar gunakan file yang terencode namun saat menghapusnya panggil file yang tidak terencode
0 Response to "Tutorial PHP : Menghapus Foto yang di Encode Base64"
Post a Comment
Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin