Upload, Tampil dan Delete Gambar di PHP Part II

 
Upload, Tampil dan Delete Gambar di PHP Part II
Upload, Tampil dan Delete Gambar di PHP Part II.
Sumber : blogs root93

ROOT93 - Pada Upload, Tampil dan Delete Gambar di PHP Part II kita akan sedikit menyempurnakan tentang tutorial sebelumnya yaitu tentang Upload, Tampil dan Delete Gambar di PHP
Dalam studi kasus kali ini kita akan membuat halaman untuk  upload, edit, update dan delete gambar/foto. Saya tidak akan menjelaskan secara rinci, saya hanya akan menunjukan beberapa baris kode yang sudah Saya tulis untuk melakukan proses Upload, Tampil dan Delete Gambar, nanti  mungkin Anda bisa mempelajarinya sendiri.

Penulisan kode kali ini berbeda dengan sebelumnya, disini saya menyimpan eksekusi untuk menyimpan, menampilkan atau mengupdate data ke database didalam function selanjutnya juga tidak seperti sebelumnya, proses CRUD gambar/foto ini juga menggunakan MySQLi dan prepared statement.

Upload, Tampil dan Delete Gambar di PHP Part II 

Sebelumnya siapkan sebuah database misal dengan nama "Mahasiswa" dan tabel dengan nama tabel_foto.
CREATE TABLE `tabel_foto` (
  `id` int(13) NOT NULL,
  `nama` varchar(30) NOT NULL,
  `foto` varchar(32) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Indexes for dumped tables
--

--
-- Indexes for table `tabel_foto`
--
ALTER TABLE `tabel_foto`
  ADD PRIMARY KEY (`id`);

--
-- AUTO_INCREMENT for dumped tables
--

--
-- AUTO_INCREMENT for table `tabel_foto`
--
ALTER TABLE `tabel_foto`
  MODIFY `id` int(13) NOT NULL AUTO_INCREMENT;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

Selanjutnya siapkan sebuah skrip untuk koneksi ke database, simpan file ini dengan nama koneksi.php. Anda bisa menuliskannya seperti berikut
<?php
define('DB_SERVER', 'localhost');
define('DB_USERNAME', 'root');
define('DB_PASSWORD', '');
define('DB_NAME', 'mahasiswa');
$koneksi = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($koneksi === false){
    die("ERROR: Could not connect. " . mysqli_connect_error());
}
?>

Selanjutnya kita akan menyimpan beberapa fungsi untuk eksekusi atau melakukan proses CRUD didalam sebuah function. Simpanlah file ini dengan nama function.php
<?php
/*This function cretaed by Ahmad Zaelani ROOT93.CO.ID

*/
function test_input($data){
  $data = trim($data);
  $data = stripslashes($data);
  $data = htmlspecialchars($data);
  return $data;
}
function simpan_foto($nama, $foto){
  global $koneksi;
  global $item_foto;
  global $upload_dir;
  
  $sql="INSERT INTO tabel_foto(nama, foto) VALUES (?,?)";

  if($stmt=mysqli_prepare($koneksi, $sql)){
        mysqli_stmt_bind_param($stmt,"ss",$param_nama, $param_foto);
        $param_nama= $nama;
        $param_foto= $item_foto;
     
          
        if(mysqli_stmt_execute($stmt)&&(move_uploaded_file($foto, $upload_dir.$item_foto))){
          $simpan=true;
          }else{
          $simpan=false;
          }
           return $simpan;
  }

          mysqli_stmt_close($stmt);
}

function update_foto($nama,$foto, $id){
  global $koneksi;
  global $item_foto;
  global $upload_dir;
  $sql = "UPDATE tabel_foto SET nama=?, foto=? WHERE id=?";
        
      if($stmt = mysqli_prepare($koneksi, $sql)){           
         mysqli_stmt_bind_param($stmt,"ssi",$param_nama, $param_foto, $param_id);
            $param_nama= $nama;
            $param_foto= $item_foto;
            $param_id= $id;
            //Query kedua untuk mengrow atau unlink
                $sql="SELECT * FROM tabel_foto where id=?";
                if($prepare=mysqli_prepare($koneksi,$sql)){
                  mysqli_stmt_bind_param($prepare, "i", $param_id);
                  mysqli_stmt_execute($prepare);
                  $result = mysqli_stmt_get_result($prepare);
                  if(mysqli_num_rows($result)==1){
                    $jalankan=mysqli_fetch_array($result);
                    $hapus_foto=unlink("folderfoto/$jalankan[foto]");
                    }else{
                    header("location: error");
                    exit();                   
                    }
                  }

        if(mysqli_stmt_execute($stmt) && ($hapus_foto) && (move_uploaded_file($foto, $upload_dir.$item_foto))){
          $simpan=true;
          }else{
          $simpan=false;
          }
                  return $simpan;
      }
            mysqli_stmt_close($stmt);
}
function tampil_foto(){
        global $koneksi;
        $sql = "SELECT id, nama, foto FROM tabel_foto order by id desc";
        $result = mysqli_query($koneksi, $sql);
        return $result;
}
function detail_foto($var_id){
  global $koneksi;
   global $row;
      $sql = "SELECT * FROM tabel_foto WHERE id = ?";
      if($stmt = mysqli_prepare($koneksi, $sql)){
          mysqli_stmt_bind_param($stmt, "i", $param_id);
          $param_id = $var_id;
          if(mysqli_stmt_execute($stmt)){     
             $result = mysqli_stmt_get_result($stmt);
              /* Menampilkan hasil menggunakan fetch array tanpa perlu looping */
              $row = mysqli_fetch_array($result, MYSQLI_ASSOC);

            if(mysqli_num_rows($result) == 1){
              return true;
              }else{                 
                return false;
              }

            }else{
              echo "Terjadi kesalahan. Coba lagi nanti";
            }
             
          }

             mysqli_stmt_close($stmt);
}
function delete_foto($id){
    global $koneksi;
    $sql = "DELETE FROM tabel_foto WHERE id = ?";
      if($stmt = mysqli_prepare($koneksi, $sql)){
         mysqli_stmt_bind_param($stmt, "i", $param_id);
         $param_id = $id;

                //Query kedua untuk mengrow atau unlink
                $sql="SELECT * FROM tabel_foto where id=?";
                if($prepare=mysqli_prepare($koneksi, $sql)){
                  mysqli_stmt_bind_param($prepare, "i", $param_id);
                  mysqli_stmt_execute($prepare);
                  $result = mysqli_stmt_get_result($prepare);
                  if(mysqli_num_rows($result)==1){
                    $jalankan=mysqli_fetch_array($result);
                    $hapus_foto=unlink("folderfoto/$jalankan[foto]");
                    }else{
                    header("location: error");
                    exit();                   
                    }
                  }
                  if(mysqli_stmt_execute($stmt) && ($hapus_foto)){
                    return true;
                     }else{
                     return false;
                   }
      }
  
      mysqli_stmt_close($stmt);
      mysqli_stmt_close($prepare);   
}
?>

Berikutnya kita akan membuat sebuah antarmuka untuk input data mahasiswa, berupa nama dan upload file foto. Beri nama file ini tb_data.php


<?php
  include ('koneksi.php');
  include ('function.php');
?>
<?php
//set variabel
$nama = $foto = $berhasil_simpan = $berhasil_simpan_err = $nama_err = $foto_err ="";   
if($_SERVER["REQUEST_METHOD"] == "POST"){
  if(empty(trim($_POST['nama']))){
           $nama_err = "Nama Mahasiswa tidak boleh kosong";     
           }elseif(strlen($_POST['nama'])>25){
           $nama_err = "Nama Mahasiswa tidak boleh lebih dari 25 karakter ";
           }else{
           $nama=test_input($_POST['nama']);
           $nama=mysqli_real_escape_string($koneksi,$nama);
    }

      $imgFile = $_FILES['foto']['name'];
      $tmp_dir = $_FILES['foto']['tmp_name'];
      $imgSize = $_FILES['foto']['size'];
      //letak direktori gambar
      $upload_dir = 'folderfoto/';
      //variabel pengecekan ektensi gambar
      $imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION)); 
      $valid_extensions = array('jpeg', 'jpg', 'png', 'gif'); 
      //Merename gambar secara random
      $item_foto = rand(1000,1000000).".".$imgExt; 
      if (!empty($_FILES["foto"]["tmp_name"])){
      if(in_array($imgExt, $valid_extensions)){  
      if(!$imgSize< 2000000){
      $foto=$tmp_dir;
      }else{
      $foto_err="Maaf file foto Mahasiswa terlalu besar. Max 2MB"; 
      } 
      }else{
      $foto_err="Maaf ektensi foto Mahasiswa tidak sesuai ketentuan";
      }
      }else{
      $foto_err = "Maaf Foto Mahasiswa masih kosong";
      }

  //Jika data error kosong maka eksekusi ke database
  if(empty($nama_err) && empty($foto_err) && empty($id_err)){
       
           if(simpan_foto($nama, $foto)){
              $berhasil_simpan = "Data berhasil disimpan <a href='lihat.php'>Lihat Data</a>";
              }else{
              $berhasil_simpan_err = "Data gagal disimpan";
              }

  }


}
?>

<html>
<head>
<title>DATA MAHASISWA</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<style type="text/css">
.error-form {color: red;}
.sukses-form{color: #0081ff;}
</style>
</head>
<body>
<div class="container">
  <div class="row">
    <div class="col-md-4">
      <div class="page-header">
      <h1>Data Mahasiswa</h1>
    </div>
<p class="sukses-form"><?php echo $berhasil_simpan; ?></p>
<p class="error-form"><?php echo $berhasil_simpan_err; ?></p>
<form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']);?>" method="post" enctype="multipart/form-data">
  <div class="form-group <?php echo (!empty($nama_err)) ? 'has-error' : ''; ?>">
      <label>Nama Mahasiswa :</label>
      <input type="text" name="nama" class="form-control" id="nama" placeholder="Masukan Nama Mahasiswa" value="<?php echo $nama; ?>">
      <span><p class="error-form"><?php echo $nama_err; ?></p></span>    
  </div>
  <div class="form-group <?php echo (!empty($foto_err)) ? 'has-error' : ''; ?>">
      <label>Foto Mahasiswa</label>   
      <input type="file" class="form-control-file" id="foto" name="foto">
      <span><p class="error-form"><?php echo $foto_err; ?></p></span>  
  </div>
  <button type="submit" class="btn btn-primary">Submit</button>
</form>
</div>
</div>
</div>
</body>
</html>

Pada tahap selanjutnya data yang sudah disimpan perlu ditampilkan pada sebuah halaman. Anda bisa membuat file baru dengan nama lihat.php dengan isi kode seperti berikut



<?php
  include ('koneksi.php');
  include ('function.php');
?>
<?php
$tampil=tampil_foto();
?>
<html>
<head>
<title>DATA MAHASISWA</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.1/css/all.css">
<style type="text/css">
.error-form {color: red;}
.sukses-form{color: #0081ff;}
</style>
</head>
<body>
<div class="container">
  <div class="row">
    <section class="col-sm-12">
      <div class="page-header">
      <h3>Lihat Data Mahasiswa</h3>
    </div>
   <div class="table-responsive">
                <?php 
                $result=tampil_foto(); //memamnggil fungsi tampil foto
                if($result){
                if(mysqli_num_rows($result) > 0){
                echo "<table class='table table-striped table-bordered table-hover'>";
                  echo "<thead>";
                    echo "<tr>";
                      echo "<th>No</th>";
                      echo "<th>Nama</th>";
                       echo "<th>Foto</th>";                  
                                     
                    echo "</tr>";
                  echo "</thead>";
    
                  echo "<tbody>";
$awal=0;
$no=$awal+1;
while($data=mysqli_fetch_array($result)) {                     
    echo "<tr>";
    echo "<td>".$no."</td>";
    echo "<td>".$data['nama']."</td>";
    echo "<td>".'<img class="img-responsive" width="80" height="100" src="folderfoto/'.$data['foto'].'"'."</td>";   
    echo "<td>";
    echo "<a href='tb_data.php' title='Tambah Data' alt='Tambah Data'><i  class='fa fa-edit fa-fw small'></i></a>";
     echo "<a href='edit-data.php?id=".$data['id']."'title='Edit Mahasiswa' alt='Edit Mahasiswa'><i class='fa fa-edit fa-fw small'></i></a>";
     echo "<a href='delete.php?id=". $data['id'] ."' title='Delete Mahasiswa' alt='Delete Mahasiswa'><i  class='fa fa-trash fa-fw small'></i></a>";

    echo "</td>";
    echo "</tr>";
  $no+=1;   
}
echo "</tbody>";
echo"</table>";
              mysqli_free_result($result);
  } else{
    echo "<p class='lead'><em>Data Mahasiswa belum ada. <a href='tb_data.php'>Tambah Data</a></em></p>";
 }
            } else{
  echo "ERROR: Tidak bisa mengeksekusi perintah. " . mysqli_error($koneksi);
  }
 //close connections
mysqli_close($koneksi);
?>
              </div>

</section>
</div>
</div>
</body>
</html>


Halaman selanjutnya adalah membuat antar muka untuk edit/update data foto. Buat file baru dengan nama edit-data.php

<?php
  include ('koneksi.php');
  include ('function.php');
?>
<?php
if(!empty($_GET['id']) && intval($_GET['id']) ){
 //memanggil fungsi detail data terlbeih dahulu
 if(detail_foto(trim($_GET['id']))){
  $foto=$row["foto"];
  $nama=$row["nama"];
  $id=$row["id"];
 }else{
  die ("Data tidak ditemukan");
 }

 }else{
   die("Data kosong atau tidak ditemukan");
  
}
?>
<?php
//set variabel err
$berhasil_simpan = $berhasil_simpan_err = $nama_err = $foto_err = $id_err ="";   
if($_SERVER["REQUEST_METHOD"] == "POST"){
  if(empty(trim($_POST['nama']))){
           $nama_err = "Nama Mahasiswa tidak boleh kosong";     
           }elseif(strlen($_POST['nama'])>25){
           $nama_err = "Nama Mahasiswa tidak boleh lebih dari 25 karakter ";
           }else{
           $nama=test_input($_POST['nama']);
           $nama=mysqli_real_escape_string($koneksi,$nama);
    }

      $imgFile = $_FILES['foto']['name'];
      $tmp_dir = $_FILES['foto']['tmp_name'];
      $imgSize = $_FILES['foto']['size'];
      //letak direktori gambar
      $upload_dir = 'folderfoto/';
      //variabel pengecekan ektensi gambar
      $imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION)); 
      $valid_extensions = array('jpeg', 'jpg', 'png', 'gif'); 
      //Merename gambar secara random
      $item_foto = rand(1000,1000000).".".$imgExt; 
      if (!empty($_FILES["foto"]["tmp_name"])){
      if(in_array($imgExt, $valid_extensions)){  
      if(!$imgSize< 2000000){
      $foto=$tmp_dir;
      }else{
      $foto_err="Maaf file foto Mahasiswa terlalu besar. Max 2MB"; 
      } 
      }else{
      $foto_err="Maaf ektensi foto Mahasiswa tidak sesuai ketentuan";
      }
      }else{
      $foto_err = "Maaf Foto Mahasiswa masih kosong";
      }
      if(empty($_POST['id'])){
      die("Terjadi keslahan, id data masing kosong");
      }else{
      $id=test_input($_POST['id']);
      $id=mysqli_real_escape_string($koneksi, $id);
      }

  //Jika data error kosong maka eksekusi ke database
  if(empty($nama_err) && empty($foto_err)){
       
           if(update_foto($nama, $foto, $id)){
              $berhasil_simpan = "Data berhasil disimpan <a href='lihat.php'>Lihat Data</a>";
             echo "<meta http-equiv=\"refresh\"content=\"2\"/>";
              }else{
              $berhasil_simpan_err = "Data gagal disimpan";
              }

  }


}
?>

<html>
<head>
<title>DATA MAHASISWA</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<style type="text/css">
.error-form {color: red;}
.sukses-form{color: #0081ff;}
</style>
</head>
<body>
<div class="container">
  <div class="row">
    <div class="col-md-4">
      <div class="page-header">
      <h1>Data Mahasiswa</h1>
    </div>
<p class="sukses-form"><?php echo $berhasil_simpan; ?></p>
<p class="error-form"><?php echo $berhasil_simpan_err; ?></p>
    <form action="<?php echo htmlspecialchars(basename($_SERVER['REQUEST_URI']));?>" method="post" enctype="multipart/form-data">
  <div class="form-group <?php echo (!empty($nama_err)) ? 'has-error' : ''; ?>">
      <label>Nama Mahasiswa :</label>
      <input type="text" name="nama" class="form-control" id="nama" placeholder="Masukan Nama Mahasiswa" value="<?php echo $nama; ?>">
       <input type="hidden" name="id" id="id" value="<?php echo $id; ?>">
      <span><p class="error-form"><?php echo $nama_err; ?></p></span>    
  </div>
  <div class="form-group <?php echo (!empty($foto_err)) ? 'has-error' : ''; ?>">
      <label>Foto Mahasiswa</label>   
      <input type="file" class="form-control-file" id="foto" name="foto">
      <span><p class="error-form"><?php echo $foto_err; ?></p></span>
      <p>
            Foto saat ini :<br>
          <img src="folderfoto/<?php echo $foto; ?>" class="img-fluid" height="100" width="100">
        </p>      
  </div>
  <button type="submit" class="btn btn-primary">Submit</button>
</form>
</div>
</div>
</div>
</body>
</html>


Terakhir kita buat file dengan nama delete.php untuk melakukan proses delete data foto/gambar dengan menggunakan perintah UNLINK untuk menghapus file yang berada di server, dan parameter query biasa untuk melakukan delete


<?php
  include ('koneksi.php');
  include ('function.php');
?>
<?php
if(!empty($_GET['id']) && intval($_GET['id']) ){
 //memanggil fungsi detail data terlbeih dahulu
 if(detail_foto(trim($_GET['id']))){
  $id=$row["id"];
 }else{
  die ("Data tidak ditemukan");
 }

 }else{
   die("Data kosong atau tidak ditemukan");
  
}
?>
<?php
//set variabel
$berhasil_simpan = $berhasil_simpan_err = $id_err ="";   
if($_SERVER["REQUEST_METHOD"] == "POST"){
  if(empty(trim($_POST['id']))){
           $id_err = "id Mahasiswa tidak boleh kosong";     
           }elseif(strlen($_POST['id'])>25){
           $id_err = "id Mahasiswa tidak boleh lebih dari 25 karakter ";
           }else{
           $id=test_input($_POST['id']);
           $id=mysqli_real_escape_string($koneksi,$id);
    }

      

  //Jika data error kosong maka eksekusi ke database
  if(empty($id_err)){
       
           if(delete_foto($id)){
              $berhasil_simpan = "Data berhasil dihapus";
               echo "<meta http-equiv=\"refresh\"content=\"1;URL=lihat.php\"/>";
              }else{
              $berhasil_simpan_err = "Data gagal disimpan";
              }

  }
}

?>

<html>
<head>
<title>DATA MAHASISWA</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<style type="text/css">
.error-form {color: red;}
.sukses-form{color: #0081ff;}
</style>
</head>
<body>
<div class="container">
  <div class="row">
    <div class="col-md-4">    
<p class="sukses-form"><?php echo $berhasil_simpan; ?></p>
<p class="error-form"><?php echo $berhasil_simpan_err; ?></p>

<form action="<?php echo htmlspecialchars(basename($_SERVER['REQUEST_URI']));?>" method="post">
  <div class="form-group <?php echo (!empty($id_err)) ? 'has-error' : ''; ?>">    
      <input type="hidden" name="id" class="form-control" id="id" placeholder="Masukan id Mahasiswa" value="<?php echo $id; ?>">
      <p>Yakin ingin mengahpus data ?</p>
      <span><p class="error-form"><?php echo $id_err; ?></p></span>    
  </div>  
  <button type="submit" class="btn btn-danger">Delete</button>
</form>
</div>
</div>
</div>
</body>
</html>

Sampai disini kita sudah selesai.

(Ahmad Zaelani /r93)

3 Responses to "Upload, Tampil dan Delete Gambar di PHP Part II"

  1. Wah baru tahu ane gan ternyata unggah & hapus gambar bisa juga pakai php ya, ane tahu nya di dashboard website aja hhhhh 😁

    ReplyDelete
  2. mohon maaf sebelumnya, mau tanya maksud dari "if (!$imgsize < 2000000)" dimana ada tanda seru ("!") pdhl jika size < 2000000 maka kondisi terpenuhi, kenapa tidak ditulis "if ($imgsize< 2000000)" saja (tanpa tanda "!") ya ?

    ReplyDelete
    Replies
    1. itu sama halnya seperti if(!empty mas mas bisa saja buat jadi if (empty perbedaannya adalah terlekat pada blok yang pertama diakses ketika kondisi terpenuh atau tidak terpenuhi, misal kalau if(!empty artinya kalau tidak kosong maka kondisi pertama masukan didalam blok, itu berbeda jika if(empty artinya jika kosong tampilkan kesalahnya

      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 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 Gama69strategi pemain pro membaca pola spin harian berdasarkan ritme dan keberuntunganhasil riset pola spin harian yang paling sering meningkatkan peluang menangpanduan efektif menentukan jam spin terbaik agar konsistensi menang terjagateknik pemain berpengalaman mengelola spin harian untuk hasil lebih stabilstudi terbaru tentang ritme spin harian yang mempengaruhi peluang keberuntungananalisis waktu tepat spin harian berdasarkan pergerakan tempo pemain prorahasia spin berirama dalam meningkatkan peluang jackpot harian pemain ahlipola tersembunyi spin harian yang sering dipakai pemain berhasil untuk menangstrategi harian mengelola kecepatan spin dan waktu hoki agar tetap stabilpenemuan pola spin beruntun yang mengubah peluang menjadi lebih menguntungkanpanduan membaca ritme spin mahjong ways harian untuk peluang jackpot lebih besarstrategi pemain pro mahjong ways dalam mengelola spin dan tempo keberuntunganhasil observasi terbaru pola spin mahjong ways yang sering memberikan hasil positifanalisis ritme spin mahjong ways berdasarkan jam hoki dan frekuensi kemenanganrahasia pemain ahli mahjong ways dalam menentukan tempo spin yang tepat untuk menangvirgobet88 ungkap pola spin harian yang sering digunakan pemain berhasilrahasia virgobet88 mengelola tempo spin dan keberuntungan agar lebih konsistenvirgobet88 bagikan panduan spin harian berdasarkan analisis waktu hokistrategi unggulan virgobet88 dalam membaca ritme dan pola spin beruntunpanduan virgobet88 meningkatkan peluang jackpot dengan spin harian terukurvirgobet88 bagikan panduan spin harian dengan strategi berdasarkan waktu emasrahasia virgobet88 memanfaatkan ritme dan tempo spin untuk peluang jackpot besarstrategi harian virgobet88 dalam menentukan jam spin yang paling menguntungkanvirgobet88 ungkap teknik spin malam hari yang sering bikin pemain menang beruntunpanduan virgobet88 membaca pola spin harian berdasarkan data dan ritme keberuntunganpanduan spin mahjong ways harian berdasarkan ritme dan keberuntungan pemain prorahasia pemain ahli mahjong ways menetapkan jam hoki spin untuk hasil lebih stabilstrategi terbaru spin mahjong ways malam hari yang sering memberikan peluang jackpotanalisis pola berirama mahjong ways dalam meningkatkan frekuensi kemenangan harianhasil observasi pemain pro mahjong ways terhadap ritme dan waktu spin hokianalisis ritme spin malam hari dan hubungannya dengan peluang keberuntungan pemainstrategi pemain berpengalaman menentukan waktu emas spin untuk hasil lebih stabilpengamatan lapangan terhadap perubahan tempo spin dan faktor penentu kemenanganhasil penelitian tentang pola spin harian yang sering memberi keuntungan tinggipanduan lengkap membaca ritme spin malam hari agar tetap maksimal di waktu hokistrategi pro menentukan tempo spin mahjong ways berdasarkan perubahan keberuntungan hariananalisis pola mahjong ways saat pergantian hari yang sering memberi jackpot besarhasil studi terbaru tentang ritme spin mahjong ways dan hubungannya dengan keberuntunganpanduan mahjong ways membaca frekuensi spin dan waktu tepat untuk menangrahasia pemain pro menemukan waktu hoki spin mahjong ways dengan metode observasistrategi pemain berpengalaman menentukan ritme spin malam yang sering memberi keuntunganhasil riset mengenai pola spin beruntun yang sering muncul saat jam keberuntunganpanduan membaca perubahan tempo spin agar peluang menang tetap stabilteknik mengatur kecepatan spin dan pola berulang untuk maksimalkan hasilanalisis waktu hoki spin malam hari berdasarkan pengalaman pemain propetimas88 bagikan strategi spin berlapis yang sering meningkatkan tingkat kemenanganrahasia petimas88 mengelola pola spin malam hari agar tetap konsisten menangpetimas88 ungkap pengaruh ritme spin beruntun terhadap peluang jackpot harianstudi petimas88 tentang waktu emas spin yang sering memberi hasil positifpanduan resmi petimas88 membaca frekuensi spin dan mengatur strategi bermainstrategi pemain berpengalaman mengatur tempo spin dan memanfaatkan momen hokianalisis ritme spin harian dalam menentukan waktu tepat untuk mendapatkan jackpottips mengenali pola spin yang sering memberi keberuntungan besar pada pemainpanduan lengkap mengelola spin harian agar peluang kemenangan tetap stabilrahasia pemain pro menentukan frekuensi spin ideal demi hasil lebih maksimalanalisis mahjong ways terhadap pola ritme spin dan hubungannya dengan keberuntunganstrategi pro mahjong ways memanfaatkan perubahan tempo spin untuk peluang lebih besarpanduan mahjong ways menemukan momen terbaik spin dengan metode pengamatan harianhasil riset pemain berhasil tentang ritme spin mahjong ways pada jam keberuntunganteknik mahjong ways meningkatkan akurasi spin dan menentukan saat paling efektif
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