Pada postingan kali ini Kantin Kampus akan meberikan sedikit tutorial dalam membuat statistik pengunjung dengan php dan mysql.
Langkah awal kita buat databasenya dulu disini saya menggunakan database test yang sudah ada di mysql, kemudian kita membuat tablenya yang kita beri nama konter, agar lebih mudah bisa menggunakan phpMyAdmin:
Langkah awal kita buat databasenya dulu disini saya menggunakan database test yang sudah ada di mysql, kemudian kita membuat tablenya yang kita beri nama konter, agar lebih mudah bisa menggunakan phpMyAdmin:
CREATE TABLE IF NOT EXISTS `konter` (
`ip` varchar(20) COLLATE latin1_general_ci NOT NULL,
`tanggal` date NOT NULL,
`hits` int(10) NOT NULL DEFAULT '1',
`online` varchar(255) COLLATE latin1_general_ci NOT NULL
)
untuk script phpnya kita bikin dalam satu file saja yang disini saya beri nama statistik_pengunjung.php
kodenya bisa dilihat dibawah ini :
<?php
$ip = $_SERVER['REMOTE_ADDR'];
$tanggal = date("Ymd");
$waktu = time();
$bln=date("m");
$tgl=date("d");
$blan=date("Y-m");
$thn=date("Y");
$tglk=$tgl-1;
$s = mysql_query("SELECT * FROM konter WHERE ip='$ip' AND tanggal='$tanggal'");
if(mysql_num_rows($s) == 0){
mysql_query("INSERT INTO konter(ip, tanggal, hits, online) VALUES('$ip','$tanggal','1','$waktu')");
}
else{
mysql_query("UPDATE konter SET hits=hits+1, online='$waktu' WHERE ip='$ip' AND tanggal='$tanggal'");
}
if($tglk=='1' | $tglk=='2' | $tglk=='3' | $tglk=='4' | $tglk=='5' | $tglk=='6' | $tglk=='7' | $tglk=='8' | $tglk=='9'){
$kemarin=mysql_query("SELECT * FROM konter WHERE tanggal='$thn-$bln-0$tglk'");
} else {
$kemarin=mysql_query("SELECT * FROM konter WHERE tanggal='$thn-$bln-$tglk'");
}
$bulan=mysql_query("SELECT * FROM konter WHERE tanggal LIKE '%$blan%'");
$bulan1=mysql_num_rows($bulan);
$tahunini=mysql_query("SELECT * FROM konter WHERE tanggal LIKE '%$thn%'");
$tahunini1=mysql_num_rows($tahunini);
$pengunjung = mysql_num_rows(mysql_query("SELECT * FROM konter WHERE tanggal='$tanggal' GROUP BY ip"));
$totalpengunjung = mysql_result(mysql_query("SELECT COUNT(hits) FROM konter"), 0);
$hits = mysql_fetch_assoc(mysql_query("SELECT SUM(hits) as hitstoday FROM konter WHERE tanggal='$tanggal' GROUP BY tanggal"));
$totalhits = mysql_result(mysql_query("SELECT SUM(hits) FROM konter"), 0);
$bataswaktu = time() - 300;
$pengunjungonline = mysql_num_rows(mysql_query("SELECT * FROM konter WHERE online > '$bataswaktu'"));
$kemarin1 = mysql_num_rows($kemarin);
echo " <table width='100%' border='0'>
<tbody><tr>
<td width='32' align='right' valign='middle'><img src='images/06.png' width='16' height='16'></td>
<td width='98' align='left' valign='middle'> Hari Ini</td>
<td width='138' align='left' valign='middle'>:
$pengunjung</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/07.png' width='16' height='16'></td>
<td align='left' valign='middle'>Kemarin</td>
<td align='left' valign='middle'>:
$kemarin1</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/08.png' width='16' height='16'></td>
<td align='left' valign='middle'>Bulan ini </td>
<td align='left' valign='middle'> :
$bulan1</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/09.png' width='16' height='16'></td>
<td align='left' valign='middle'>Tahun ini </td>
<td align='left' valign='middle'>:
$tahunini1</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/bar_chart.png' width='16' height='16'></td>
<td width='98' align='left' valign='middle'>Total</td>
<td width='138' align='left' valign='middle'>:
$totalhits</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/line_chart.png' width='16' height='16'></td>
<td align='left' valign='middle'>Hits Count </td>
<td align='left' valign='middle'>:
$hits[hitstoday]</td>
</tr>
<tr>
<td align='right' valign='middle'><img src='images/06.png' width='16' height='16'></td>
<td width='98' align='left' valign='middle'>Now Online</td>
<td width='138' align='left' valign='middle'>:
<b>$pengunjungonline</b> User</td>
</tr>
</tbody></table>";
?>
Semoga bisa membantu teman-teman Kantin Kampus.
0 komentar:
Post a Comment