UTS PWeb

Nama: Donny Fitrado
NRP: 05111740000171
Kelas: PWeb C

Kali ini, saya akan membagikan hasil UTS PWeb saya yaitu membuat E-Rapor untuk prestasi siswa. Berikut ini adalah source codenya:

1. config.php
 <?php  
 $server = "localhost";  
 $user = "root";  
 $password = "";  
 $nama_database = "pendaftaran_siswa";  
 $db = mysqli_connect($server, $user, $password, $nama_database);  
 if( !$db ){  
   die("Gagal terhubung dengan database: " . mysqli_connect_error());  
 }  
 ?>  

2. index.php
 <!DOCTYPE html>  
 <html>  
 <head>  
   <title>E-Rapor Siswa | SMAS Cita Hati</title>  
 </head>  
 <body>  
   <header>  
     <h3>Pendaftaran Prestasi</h3>  
     <h1>SMAS Cita Hati</h1>  
   </header>  
   <h4>Menu</h4>  
   <nav>  
     <?php if(isset($_GET['status'])): ?>  
   <p>  
     <?php  
       if($_GET['status'] == 'sukses'){  
         echo "Pendaftaran siswa baru berhasil!";  
       } else {  
         echo "Pendaftaran gagal!";  
       }  
     ?>  
   </p>  
 <?php endif; ?>  
     <ul>  
       <li><a href="form-daftar.php">Tambah Prestasi Siswa</a></li>  
       <li><a href="list-siswa.php">List Prestasi Siswa</a></li>  
     </ul>  
   </nav>  
   </body>  
 </html>  

3. form-daftar.php
 <!DOCTYPE html>  
 <html>  
 <head>  
   <title>Formulir Pendaftaran Prestasi | SMAS Cita Hati</title>  
 </head>  
 <body>  
   <header>  
     <h3>Formulir Pendaftaran Prestasi Siswa</h3>  
   </header>  
   <form action="proses-pendaftaran.php" method="POST">  
     <fieldset>  
     <p>  
       <label for="nama">Nama: </label>  
       <input type="text" name="nama" placeholder="nama lengkap" />  
     </p>  
     <p>  
       <label for="nis">NIS: </label>  
       <input type="text" name="nis" placeholder="nomor induk siswa" />  
     </p>  
     <p>  
       <label for="semester">Semester: </label>  
       <label><input type="radio" name="semester" value="gasal"> Gasal</label>  
       <label><input type="radio" name="semester" value="genap"> Genap</label>  
     </p>  
     <p>  
       <label for="kelas">Kelas </label>  
       <select name="kelas">  
         <option>10 IPA1</option>  
         <option>10 IPA2</option>  
         <option>10 IPS</option>  
         <option>11 IPA</option>  
         <option>11 IPS</option>  
         <option>12 IPA1</option>  
         <option>12 IPA2</option>  
         <option>12 IPS1</option>  
         <option>12 IPS2</option>  
       </select>  
     </p>  
     <p>  
       <label for="prestasi">Prestasi: </label>  
       <textarea name="prestasi"></textarea>  
     </p>  
     <p>  
       <input type="submit" value="Daftar" name="daftar" />  
     </p>  
     </fieldset>  
   </form>  
   </body>  
 </html>  

4. proses-pendaftaran.php
 <?php   
  include("config.php");   
  if(isset($_POST['daftar'])){   
   // ambil data dari formulir   
    $kelas = $_POST['kelas'];   
    $semester = $_POST['semester'];   
   $nama = $_POST['nama'];   
   $nis = $_POST['nis'];   
   $jenis_prestasi = $_POST['prestasi'];   
   $keterangan = $_POST['keterangan'];   
   // buat query   
   $sql = "INSERT INTO data_prestasi (kelas, semester, nama, nis, prestasi, keterangan) VALUE ('$kelas', '$semester', '$nama', '$nis', '$prestasi', '$keterangan')";   
   $sql = "INSERT INTO data_prestasi (kelas, semester, nama, nis, prestasi, keterangan) VALUE ('$kelas', '$semester', '$nama', '$nis', '$prestasi', '$keterangan')";   
   $query = mysqli_query($db, $sql);   
   // apakah query simpan berhasil?   
   if( $query ) {   
    // kalau berhasil alihkan ke halaman index.php dengan status=sukses   
    header('Location: index.php?status=sukses');   
   } else {   
    // kalau gagal alihkan ke halaman indek.php dengan status=gagal   
    header('Location: index.php?status=gagal');   
   }   
  } else {   
   die("Akses dilarang...");   
  }   
  ?>   

5. list-siswa.php
 <?php include("config.php"); ?>   
  <!DOCTYPE html>   
  <html>   
  <head>   
   <title>Daftar Prestasi</title>   
  </head>   
  <body>   
   <header>   
    <h3>Pendaftaran Prestasi Siswa | SMAS Cita Hati</h3>   
   </header>   
   <nav>   
    <a href="form-daftar.php">[+] Tambah Baru</a>   
   </nav>   
   <br>   
   <table border="1">   
   <thead>   
    <tr>   
     <th>NIS</th>   
     <th>Nama</th>   
     <th>Semester</th>   
     <th>Kelas</th>   
     <th>Prestasi</th>   
     <th>Keterangan</th>   
         <th>Aksi</th>   
    </tr>   
   </thead>   
   <tbody>   
    <?php   
    $sql = "SELECT * FROM data_prestasi";   
    $query = mysqli_query($db, $sql);   
    while($siswa = mysqli_fetch_array($query)){   
     echo "<tr>";   
     echo "<td>".$siswa['nis']."</td>";  
     echo "<td>".$siswa['nama']."</td>";  
     echo "<td>".$siswa['kelas']."</td>";   
     echo "<td>".$siswa['semester']."</td>";    
     echo "<td>".$siswa['prestasi']."</td>";   
         echo "<td>".$siswa['keterangan']."</td>";   
     echo "<td>";   
     echo "<a href='form-edit.php?id=".$siswa['id']."'>Edit</a> | ";   
     echo "<a href='hapus.php?id=".$siswa['id']."'>Hapus</a>";   
     echo "</td>";   
     echo "</tr>";   
    }   
    ?>   
   </tbody>   
   </table>   
   <p>Total: <?php echo mysqli_num_rows($query) ?></p>   
   </body>   
  </html>   

6. form-edit.php
 <?php   
  include("config.php");   
  // kalau tidak ada id di query string   
  if( !isset($_GET['id']) ){   
   header('Location: list-siswa.php');   
  }   
  //ambil id dari query string   
  $id = $_GET['id'];   
  // buat query untuk ambil data dari database   
  $sql = "SELECT * FROM data_prestasi WHERE id=$id";   
  $query = mysqli_query($db, $sql);   
  $siswa = mysqli_fetch_assoc($query);   
  // jika data yang di-edit tidak ditemukan   
  if( mysqli_num_rows($query) < 1 ){   
   die("data tidak ditemukan...");   
  }   
  ?>   
  <!DOCTYPE html>   
  <html>   
  <head>   
   <title>Edit Prestasi Siswa</title>   
  </head>   
  <body>   
   <header>   
    <h3>Formulir Edit Prestasi Siswa</h3>   
   </header>   
   <form action="proses-edit.php" method="POST">   
    <fieldset>   
     <input type="hidden" name="id" value="<?php echo $siswa['id'] ?>" />   
       <p>   
     <label for="kelas">Kelas: </label>   
     <?php $kelas = $siswa['kelas']; ?>   
     <select name="kelas">   
      <option <?php echo ($kelas == 'X IPA 1') ? "selected": "" ?>>10 IPA 1</option>   
      <option <?php echo ($kelas == 'X IPA 2') ? "selected": "" ?>>10 IPA 2</option>   
      <option <?php echo ($kelas == 'X IPS 1') ? "selected": "" ?>>10 IPS</option>   
      <option <?php echo ($kelas == 'XI IPA 1') ? "selected": "" ?>>11 IPA</option>    
      <option <?php echo ($kelas == 'XI IPS 1') ? "selected": "" ?>>11 IPS </option>   
            <option <?php echo ($kelas == 'XII IPA 1') ? "selected": "" ?>>12 IPA 1</option>   
      <option <?php echo ($kelas == 'XII IPA 2') ? "selected": "" ?>>12 IPA 2</option>   
      <option <?php echo ($kelas == 'XII IPS 1') ? "selected": "" ?>>12 IPS 1</option>   
       <option <?php echo ($kelas == 'XII IPS 1') ? "selected": "" ?>>12 IPS 2</option>   
     </select>   
    </p>   
       <p>   
     <label for="semester">Semester: </label>   
     <?php $semester = $siswa['semester']; ?>   
     <select name="semester">   
      <option <?php echo ($semester == '1') ? "selected": "" ?>>1</option>   
      <option <?php echo ($semester == '2') ? "selected": "" ?>>2</option>   
     </select>   
    </p>   
    <p>   
     <label for="nama">Nama: </label>   
     <input type="text" name="nama" placeholder="Nama Lengkap" value="<?php echo $siswa['nama'] ?>" />   
    </p>   
       <p>   
     <label for="nis">NIS: </label>   
     <input type="text" name="nis" placeholder="Masukkan NIS" value="<?php echo $siswa['nama'] ?>" />   
    </p>   
       <p>   
     <label for="prestasi">Jenis Prestasi: </label>   
     <?php $prestasi = $siswa['prestasi']; ?>   
     <select name="prestasi">   
      <option <?php echo ($prestasi == 'Akademik') ? "selected": "" ?>>Akademik</option>   
      <option <?php echo ($prestasi == 'Kurikuler') ? "selected": "" ?>>Kurikuler</option>   
            <option <?php echo ($prestasi == 'Lainnya') ? "selected": "" ?>>Lainnya</option>   
         </select>   
    </p>   
       <p>   
     <label for="keterangan">Keterangan: </label>   
     <textarea name="keterangan" placeholder="Masukkan keterangan prestasi"><?php echo $siswa['keterangan'] ?></textarea>   
    </p>   
    <p>   
     <input type="submit" value="Simpan" name="simpan" />   
    </p>   
    </fieldset>   
   </form>   
   </body>   
  </html>   

7. proses-edit.php
 <?php   
  include("config.php");   
  // cek apakah tombol simpan sudah diklik atau blum?   
  if(isset($_POST['simpan'])){   
   // ambil data dari formulir   
   $id = $_POST['id'];   
   $kelas = $_POST['kelas'];   
    $semester = $_POST['semester'];   
   $nama = $_POST['nama'];   
   $nis = $_POST['nis'];   
   $prestasi = $_POST['prestasi'];   
   $keterangan = $_POST['keterangan'];   
   // buat query update   
   $sql = "UPDATE data_prestasi SET kelas='$kelas', semester='$semester', nama='$nama', nis='$nis', prestasi='$prestasi', keterangan='$keterangan' WHERE id=$id";   
   $query = mysqli_query($db, $sql);   
   // apakah query update berhasil?   
   if( $query ) {   
    // kalau berhasil alihkan ke halaman list-siswa.php   
    header('Location: list-siswa.php');   
   } else {   
    // kalau gagal tampilkan pesan   
    die("Gagal menyimpan perubahan...");   
   }   
  } else {   
   die("Akses dilarang...");   
  }   
  ?>   

8. hapus.php
  <?php   
  include("config.php");   
  if( isset($_GET['id']) ){   
   // ambil id dari query string   
   $id = $_GET['id'];   
   // buat query hapus   
   $sql = "DELETE FROM data_prestasi WHERE id=$id";   
   $query = mysqli_query($db, $sql);   
   // apakah query hapus berhasil?   
   if( $query ){   
    header('Location: list-siswa.php');   
   } else {   
    die("gagal menghapus...");   
   }   
  } else {   
   die("akses dilarang...");   
  }   


Berikut ini adalah tampilannya:





Terima kasih dan mohon maaf apabila ada kesalahan.

Comments

Popular posts from this blog

EAS PBKK A

Tugas 2 - Pemrograman Web

Tugas PBO - Tech Support