Mengeset Default Foto Pada File Upload PHP
Mengeset Default Foto Pada File Upload PHP |
Langsung saja pada inti permasalahannya, misalnya Anda ingin memenuhi sebuah kondisi dimana ketika user tidak melakukan sebuah upload foto, maka secara otomatis sistem akan memberikan default foto untuknya.
IDE AWAL
Saya akan berikan contoh simpel bagaimana mengeset default foto user ketika user tersebut tidak menambahkan foto pada halaman file upload. Sederhanya Anda bisa mengeset nilai variabel kosong pada temporari file sehingga pada saat proses insert maka data tersebut akan bernilai kosong didatabase. Nilai kosong yang terdapat pada database tersebut bisa Anda manfaatkan untuk dicek pada saat pemanggilan file gambar atau foto misalnya didalam perulangan. Didalam perulangan tersebut dibuat percabangan untuk mengecek apakah ada nama foto atau tidak, jika tidak ada arahkan pemanggilan file fotonya ke default foto sedangkan jika ada maka pemanggilannya diarahkan ke direktori atau file foto yang di unggah sebelumnya
PROSES UPLOAD
Pada bagian proses upload, Anda bisa mengecek kondisi atau nilai file yang dikirim dimana disana nanti perlu dibuat percabangan, jika kosong maka set variabel nilai temporari filenya menjadi kosong. Kemudian percabangan kedua lakukan validasi jika memang ada file yang diupload sesuai dengan kebutuhan. Untuk memahami hal ini, sebaiknya Anda perlu membaca artikel sebelumnya
Pada file upload bagian input, buat kondisi seperti ini :
<?php
include ('koneksi.php');
include ('function.php');
?>
<?php
//set variabel
$nim = $nama_mahasiswa = $foto_mahasiswa = "";
$nim_err = $nama_mahasiswa_err = $foto_mahasiswa_err = "";
if($_SERVER["REQUEST_METHOD"] == "POST"){
if(empty(trim($_POST['nim']))){
$nim_err = "Nim tidak boleh kosong";
}else{
$nim=$_POST['nim'];
$nim=mysqli_real_escape_string($koneksi, $nim);
}
if(empty(trim($_POST['nama_mahasiswa']))){
$nama_mahasiswa_err = "Nama mahasiswa tidak boleh kosong";
}else{
$nama_mahasiswa = $_POST['nama_mahasiswa'];
$nama_mahasiswa = mysqli_real_escape_string($koneksi, $nama_mahasiswa);
}
if (empty($_FILES["foto_mahasiswa"]["tmp_name"])){
//ketika kondisi data kosong
$imgFile = "";
$tmp_dir = "";
$upload_dir = '';
$item_foto = '';
$foto_mahasiswa=$tmp_dir;
}else{
//ketika user mengsisi file upload
$imgFile = $_FILES['foto_mahasiswa']['name'];
$tmp_dir = $_FILES['foto_mahasiswa']['tmp_name'];
$imgSize = $_FILES['foto_mahasiswa']['size'];
$upload_dir = 'foto/';
$imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION));
$valid_extensions = array('jpeg', 'jpg', 'png', 'gif');
$item_foto = rand(1000,1000000).".".$imgExt;
if(in_array($imgExt, $valid_extensions)){
if($imgSize > 400000){
$foto_mahasiswa_err="Foto terlalu besar.Max 400KB";
}else{
$foto_mahasiswa=$tmp_dir;
}
}else{
$foto_mahasiswa_err="Ektensi Foto siswa tidak sesuai ketentuan upload, format JPEG, PNG";
}
}
//cek input sebelum insert untuk memastikan tidak ada data yang error
if(empty($nim_err) && empty($nama_mahasiswa_err) && empty($foto_mahasiswa_err)){
/* Panggil function */
if(simpan_mahasiswa($nim, $nama_mahasiswa, $foto_mahasiswa)){
echo 'Berhasil menyimpan data';
echo "<a href='tampil_data.php'>Tampil data</a>";
}else{
echo 'Gagal menyimpan data';
}
}
mysqli_close($koneksi);
//close koneksi
//end POST
}
?>
<html>
<head>
<title>Input Mahasiswa root93</title>
</head>
<body>
<form method="post" action="<?php echo $_SERVER['PHP_SELF'] ?>" enctype="multipart/form-data" />
<label>Nim :</label>
<input type="text" name="nim" size="15" />
<label>Nama Mahasiswa :</label>
<input type="text" name="nama_mahasiswa" size="15" />
<label>Foto</label>
<input type="file" name="foto_mahasiswa" id="foto_mahasiswa" />
<input type="Submit" name="submit" value="Submit">
</form>
<?php echo $nim_err; ?>
<?php echo $nama_mahasiswa_err; ?>
<?php echo $foto_mahasiswa_err; ?>
</body>
</html>
Selanjutnya pada function Anda bisa mengesetnya seperti ini :
<?php
//function simpan data
function simpan_mahasiswa($nim, $nama_mahasiswa, $foto_mahasiswa){
global $koneksi;
global $upload_dir;
global $item_foto;
$sql="INSERT INTO datamhs(nim, nama_mahasiswa, foto_mahasiswa) VALUES (?,?,?)";
if($stmt=mysqli_prepare($koneksi, $sql)){
mysqli_stmt_bind_param($stmt,"sss",$param_nim, $param_nama_mahasiswa, $param_foto_mahasiswa);
$param_nim = $nim;
$param_nama_mahasiswa = $nama_mahasiswa;
$param_foto_mahasiswa = $item_foto;
//cek apakah nilai var kosong atau tidak, jika kosong eksekusi tanpa move
if(empty($foto_mahasiswa)){
if(mysqli_stmt_execute($stmt)){
return true;
}else{
return false;
}
}else{
if(mysqli_stmt_execute($stmt)&&(move_uploaded_file($foto_mahasiswa, $upload_dir.$item_foto))){
return true;
}else{
return false;
}
}
}
//Close statement
mysqli_stmt_close($koneksi);
//End function
}
?>
PROSES PENGECEKAN PADA PERULANGAN/PEMANGGILAN DEFAULT FOTO
Seperti yang dijelaskan pada ide awal, Anda bisa membuat percabangan didalam perulangan saat melakukan pemanggilan file, jika didalam database file yang dimaksud tidak ada maka arahkan perulangan hanya untuk nilai kosong tersebut ke default foto, dan jika ada jalankan dan arahkan nilai pada kondisi normal. Contoh pemanggilan atau percabangannya bisa Anda buat kurang lebih seperti berikut :
<?php
include ('koneksi.php');
include ('function.php');
?>
<html>
<head>
<title>Menampilkan data root93.co.id</title>
</head>
<body>
<?php
//memanggi function
$result = tampil_data();
//mengeksekusi function didalam percabangan
if($result){
//jika data di tabel lebih besar dari 0 atau memiliki data maka eksekusi perulangan atau looping
if(mysqli_num_rows($result)>0){
echo "<table border='1' width='500'>";
echo "<tr>";
echo "<th>ID</th>";
echo "<th>NIM</th>";
echo "<th>NAMA MAHASISWA</th>";
echo "<th>FOTO</th>";
echo "<th>AKSI</th>";
echo "</tr>";
//loping data
while($row=mysqli_fetch_array($result)){
echo "<tr>";
echo "<td>".$row['id']."</td>";
echo "<td>".$row['nim']."</td>";
echo "<td>".$row['nama_mahasiswa']."</td>";
if(empty($row['foto_mahasiswa'])){
//jika isi nama foto sama dengan default_foto.jpg maka rubah arah src img
echo "<td><img height='100px' width='80px' src='default_foto.jpg' /></td>";
}else{
echo "<td><img height='100px' width='80px' src='foto/".$row['foto_mahasiswa']."' /></td>";
}
echo "<td>";
echo "<a href='delete.php?id=".$row['id']." 'title = 'delete'>DELETE</a>";
echo " | ";
echo "<a href='detail.php?id=".$row['id']." 'title= detail'>DETAIL</a>";
echo " | ";
echo "<a href='update.php?id=".$row['id']." 'title= update'>UPDATE</a>";
echo "</td>";
echo "</tr>";
}
echo "</table>";
echo "<a href='input.php'>Input data</a>";
//free result
mysqli_free_result($result);
//namun jika tidak lebih besar dari pada > 0 atau tidak ditemukan data maka jalan perintah berikut
}else{
echo "Data masih kosong";
}
//percabangan result ketika function tidak bisa mengeksekusi perintah
}else{
echo "Terjadi kesalahan. Coba lagi nanti".mysqli_error($koneksi);
}
//close koneksi
mysqli_close($koneksi);
?>
</body>
</html>
- Jika pada proses edit user dapat mengabaikan bagian isian foto
- Selanjutnya jika sebelumnya sudah mengisi file/foto, user yang mengabaikan bagian file upload, maka dengan otomatis sistem akan menyimpan foto sebelumnya yang dia upload
- Dan kondisi ketiga ketika misalnya memang ada file foto yang di upload, maka sistem perlu mengunggahnya.
Semua proses penulisan code saya mungkin akan sulit dipahami alurnya atau tekniknya jika Anda tidak mengikutinya dari awal, atau Anda bisa membaca artikel berikut : Silahkan Baca : CRUD PHP Procedural Style
Terus terang saya bingung nih. kirain kayak membuat kode html tema blog. Ternyata beda.
ReplyDeleteSy velom pernah sih klo pake php
ReplyDeleteSy taunya jpg doang
Thx ilmunya
Pernah belajar secara instan ttg CRUD nih. Bikin kamus
ReplyDeleteselalu ada pelajaran bila masuk blog ini begitu luar biasa
ReplyDeleteBelajar ah lewat nge view YouTubemu
ReplyDelete:)