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
    Replies
    1. mungkin pas move filenya

      Delete

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin

Virgobet88lotre4dBandar Lotre4DGama69RajajagoGama69GAMA69RajaJagohttps://linkr.bio/gama69https://mez.ink/rajajagohokiToto Slot 4D Lotre4DLotre4D Onlinevirgobet88 daftarRajajago GameVirgobet88Slot Virgobet88Linkr Virgobet88Virgobet88strategi harian mahjong ways untuk menentukan waktu emas spin dengan akurasi tinggipanduan mahjong ways membaca pola spin dan keberuntungan berdasarkan ritme harianteknik pro mahjong ways mengelola spin beruntun agar peluang jackpot lebih besarhasil analisis mahjong ways terkait ritme dan tempo spin yang paling efektifrahasia mahjong ways menyesuaikan kecepatan spin untuk hasil stabil dan menguntungkanstrategi pemain berpengalaman menentukan ritme spin berdasarkan waktu hokipola spin harian yang sering digunakan pemain pro untuk meningkatkan peluangpanduan membaca perubahan tempo spin agar lebih konsisten dalam bermainhasil riset terbaru tentang ritme spin dan korelasi keberuntungan pemainteknik pro menentukan jadwal spin harian yang paling efektif untuk stabilitasstrategi harian pemain pro menentukan waktu spin berdasarkan perubahan keberuntunganpanduan membaca ritme dan tempo spin untuk meningkatkan peluang jackpotteknik pemain berpengalaman mengatur kecepatan spin dan menentukan jam hokihasil analisis spin harian berdasarkan pola ritme dan frekuensi kemenanganrahasia pemain pro dalam menentukan momen emas spin yang paling efektifvirgobet88 bagikan strategi spin terbaru dengan analisis waktu hoki yang terbuktitips efektif dari virgobet88 untuk membaca pola spin dan perubahan keberuntunganvirgobet88 ungkap rahasia spin harian berdasarkan data dan kebiasaan pemainpanduan virgobet88 menentukan ritme spin yang konsisten untuk hasil stabilstrategi hoki virgobet88 memanfaatkan waktu tepat spin dan kecepatan bermainstrategi harian pemain pro menentukan pola spin berdasarkan ritme dan keberuntunganpanduan efektif membaca waktu emas spin agar peluang kemenangan meningkathasil penelitian tentang ritme dan tempo spin yang mempengaruhi peluang jackpotrahasia pemain berpengalaman memanfaatkan perubahan tempo spin untuk hasil stabilteknik pro menentukan jam hoki spin dan pola beruntun yang paling efektifstrategi harian mahjong ways dalam memanfaatkan ritme spin dan perubahan keberuntunganpanduan mahjong ways menentukan waktu hoki spin agar peluang jackpot meningkatanalisis mahjong ways terkait tempo spin dan konsistensi kemenangan pemainrahasia pro mahjong ways dalam mengatur spin beruntun dan kecepatan hariantips efektif mahjong ways menyesuaikan ritme dan frekuensi spin untuk hasil optimalstrategi harian pemain pro memanfaatkan ritme dan frekuensi spin untuk meningkatkan bonuspola spin efektif yang digunakan pemain berpengalaman saat perubahan tempo hariananalisis waktu hoki dalam menentukan momen tepat spin agar keuntungan maksimalteknik berlapis spin harian untuk membangun pola beruntun dan peluang jackpotrahasia pemain berhasil mengatur kecepatan spin dan menang lebih konsistenpetimas88 ungkap strategi berlapis spin dan pola hoki untuk bonus lebih seringpetimas88 bagikan cara menentukan jam emas spin agar peluang kemenangan meningkatpetimas88 analisis pola spin harian yang sering memberi keuntungan besarteknik spin pro dari petimas88 dalam mengelola tempo dan frekuensi bermainpetimas88 tips mengatur ritme spin dan meningkatkan stabilitas kemenanganstrategi pemain pro membaca ritme dan waktu emas spin agar peluang bonus naik drastisanalisis ritme spin harian dan cara menentukan momen hoki untuk kemenangan stabilpanduan lengkap mengenali pola spin berirama yang sering munculkan bonus besarrahasia waktu hoki dalam spin harian yang sering digunakan pemain berpengalamantips membaca pola dan kecepatan spin agar tidak kehilangan peluang jackpotstrategi spin mahjong ways membaca perubahan tempo dan menang lebih konsistenpanduan mahjong ways menentukan jam emas spin dan meningkatkan hoki harianteknik pemain pro mahjong ways mengatur ritme spin untuk hasil lebih stabilanalisis mahjong ways terhadap pola spin berlapis yang bisa bikin peluang jackpot naikrahasia mahjong ways memanfaatkan perubahan tempo spin dalam mencapai maxwinstrategi spin harian memanfaatkan ritme dan waktu hoki untuk peluang bonus lebih besarrahasia pemain pro menentukan tempo spin yang sering munculkan kemenangan beruntunpanduan lengkap memilih waktu emas spin agar peluang menang naik drastisanalisis perubahan ritme spin dan pengaruhnya terhadap hasil kemenangan hariantrik pemain berpengalaman mengatur kecepatan spin demi hasil stabil dan menguntungkanstrategi mahjong ways mengatur tempo dan waktu spin untuk meningkatkan keberuntunganpanduan pro mahjong ways membaca pola dan kecepatan spin agar peluang jackpot lebih besaranalisis pola spin mahjong ways dalam menentukan momen emas untuk menang konsistenrahasia mahjong ways memanfaatkan ritme harian spin dan perubahan keberuntunganteknik efektif mahjong ways menyesuaikan kecepatan spin untuk mendapatkan maxwinpanduan membaca ritme dan frekuensi spin harian untuk meningkatkan peluang jackpotstrategi pemain pro menentukan tempo spin harian dan waktu hoki paling menguntungkananalisis ritme spin berdasarkan perubahan keberuntungan dan pola pergerakan hariantrik mengatur kecepatan spin demi kemenangan stabil dalam sesi bermain harianrahasia pemain berhasil menemukan pola spin harian yang sering memberi hasil positifvirgobet88 ungkap hasil analisis ritme spin harian yang berpengaruh pada peluang maxwinstrategi virgobet88 memanfaatkan frekuensi dan ritme spin untuk meningkatkan peluang kemenanganvirgobet88 bagikan teknik mengatur tempo spin dan waktu emas agar hasil lebih stabilhasil riset virgobet88 tentang perubahan ritme spin dan pengaruhnya terhadap keberuntunganpanduan virgobet88 menentukan ritme dan frekuensi spin optimal untuk hasil maksimalstrategi pemain pro membaca pola spin berdasarkan ritme dan waktu hariananalisis ritme spin dan frekuensi keberuntungan yang sering digunakan pemain ahlipanduan mengenali waktu emas spin dan momen hoki dalam setiap permainanrahasia pola spin harian yang mampu meningkatkan kesempatan jackpot besartips mengatur tempo dan kecepatan spin agar keberuntungan lebih stabilstrategi mahjong ways memanfaatkan ritme dan perubahan spin untuk peluang maksimalrahasia pemain pro mahjong ways menentukan waktu hoki dari pola ritme hariananalisis mahjong ways terkait pola dan frekuensi spin beruntun yang menguntungkanpanduan harian mahjong ways menyesuaikan tempo spin dengan perubahan keberuntungantips pro mahjong ways mengatur ritme spin dan membaca pola hoki setiap sesistrategi pemain pro membaca pola spin harian untuk memaksimalkan keberuntungananalisis ritme dan frekuensi spin yang sering dipakai pemain ahli untuk jackpotrahasia spin berirama dan pengaturan tempo yang efektif untuk hasil stabilpanduan harian memanfaatkan waktu emas spin dalam meningkatkan peluang menangtips pemain berpengalaman menentukan jam hoki dan tempo spin paling menguntungkanpetimas88 bagikan strategi spin harian dengan pola dan ritme beruntun yang terujiteknik petimas88 menentukan perubahan tempo spin untuk hasil lebih menguntungkanpetimas88 ungkap rahasia pola spin berirama yang sering berbuah kemenangan besarpanduan lengkap petimas88 membaca perubahan spin harian berdasarkan data keberuntunganpetimas88 strategi bermain dengan analisis ritme spin dan pola keberuntungan terbaruanalisis pola ritme spin malam hari yang sering dipakai pemain untuk menang besarstrategi pemain pro memanfaatkan jam hoki malam untuk peluang jackpot lebih tinggistudi terbaru tentang pengaruh tempo spin malam terhadap tingkat kemenanganpanduan harian mengenali waktu emas spin pada malam hari agar lebih menguntungkanrahasia pemain berpengalaman mengelola spin malam dengan pola beruntun efektifstrategi spin mahjong ways di malam hari yang sering menghasilkan keberuntungan besarpanduan membaca pola mahjong ways malam hari untuk meningkatkan peluang jphasil observasi pemain pro terhadap ritme spin mahjong ways di jam hokianalisis waktu terbaik spin mahjong ways malam hari berdasarkan data pemain berhasilrahasia pola mahjong ways malam hari yang sering memicu kemenangan beruntunfreelancer canva dapat bonus harian berkat tips bermain mahjong ways 3 konsistenibu laundry medan cuan dari scatter spiral mahjong ways 2 di jam 10 pagipenjual nasi kuning cuan lewat tips bermain turbo spiral mahjong ways 3 manualibu warung di sidoarjo menang game lewat kombinasi spiral spiral di mahjong ways 2tukang cukur pakai mahjong ways 2 dan dapat rp1 1 juta dari spiral manual 5xpenjual tahu gejrot main spiral turbo jam 7 pagi lewat mahjong ways 3 manualmahasiswi manajemen sukses ulang pola spin turbo mahjong ways 2 untuk bonusmahasiswi psikologi pakai scatter jam 9 di mahjong ways 3 dan balik modal cepatpegawai fotokopi di depok main mahjong ways 2 dan menang lewat pola spiral lamapenjaga minimarket menang game setelah coba tips bermain mahjong ways 3mahasiswa teknik industri bongkar cara menang spiral spiral mahjong ways 2 manualpenjual kue lapis dapat rp1 2 juta karena pola spin turbo pagi mahjong ways 3mahasiswa arsitektur dapat rp1 4 juta dari kombinasi scatter mahjong ways 2 subuhibu rumah tangga di cimahi menang game karena turbo spiral mahjong ways 3 jam 6mahasiswi ilmu komunikasi ungkap pola spin rahasia mahjong ways 3 hari rabupenjual lontong sayur dapat tambahan dari mahjong ways 3 berkat scatter subuhsupir ojek online palembang menang game karena scatter spiral mahjong ways 2freelancer jasa posting sosmed cuan lewat tips bermain mahjong ways 2 jam pagisupir pangkalan cuan karena spin turbo 3 detik mahjong ways 3 konsistenmahasiswa desain produk pakai mahjong ways 2 untuk menang lewat scatter delaymahasiswa informatika coba spiral ganjil genap dan cuan dari mahjong ways 2penjaga toko bangunan menang game setelah coba pola spiral turbo mahjong ways 3supir truk banjarmasin dapat rp1 juta dari spiral spiral mahjong ways 2 hari libursupir angkot bekasi main scatter ganjil genap dan menang mahjong ways 2 jam subuhpenjual es teh manis menang game karena spiral mahjong ways 3 delay pola ganjilsupir truk antar kota pakai mahjong ways 2 untuk menang game lewat scatter spiralpenjual bakso di solo ungkap cara menang spiral spiral mahjong ways 3 tanpa resetibu warteg jakarta cuan dari pola spiral mahjong ways 3 setiap hari seninpenjual sate klathak di jogja menang game karena pola spin turbo mahjong ways 3ibu penjual bubur ayam dapat tambahan uang dari spiral spiral mahjong ways 2Lucky Neko Gama69
analisis nilai mahjong ways untuk peningkatan disiplin kerjaimplementasi mahjong ways dalam dunia bisnis modernimplementasi filosofi mahjong ways dalam pelatihan layanan publikmahasiswa ekonomi belajar strategi bisnis dari mahjong waysnilai edukatif mahjong ways bagi pekerja sosialnilai edukatif mahjong ways untuk profesi arsitek mudanilai filosofi mahjong ways untuk profesi penelitinilai filosofis mahjong ways pada pendidikan guru paudnilai ketelitian mahjong ways untuk profesi editor bukunilai kesabaran dalam mahjong ways bagi profesi sopir angkotcara baru mudah menang pahami pola rtp ini dan rahasia orang dalamcara menang efektif dengan pola menang yang dibocorkan pragmaticcara menang pakai pola menang ampuh bocoran orang dalam pgsoftpahami pola rtp ini untuk cara menang berdasarkan bocoran pragmaticpola menang rahasia cara menang mudah ternyata ini caranyaternyata ini caranya trik menang paling mudah dari orang dalam pgsofttrik menang dari bocoran orang dalam pgsoft ternyata ini caranyatrik menang pahami pola rtp ini cara baru mudah menangtrik menang pahami pola rtp ini ternyata ini caranya dari orang dalam pragmaticpola menang rahasia cara menang mudah ternyata ini caranya