Kamis, 11 Desember 2008
Membuat Counter dengan MySQL
Kali ini saya mau menjelaskan tentang bagaimana cara membuat counter
sebuah website dengan memakai MySql database.
caranya:
Table database:
CREATE TABLE `counter` (
`count_id` varchar(225) NOT NULL default '',
`count` longtext NOT NULL,
`hits` longtext NOT NULL
) TYPE=MyISAM;
catatan:
sebagai permulaan
untuk "count_id" anda masukkan nilai 1
untuk "count" anda masukkan nilai 1
untuk "hits" anda masukkan nilai 1
Script Counter:
session_start();
/* ----- koneksi database mulai ------- */
$dbhost = 'localhost'; /* ----- host mu ------- */
$dbusername = 'anggi'; /* ----- user mu ------- */
$dbpasswd = 'passwordku'; /* ----- password mu ------- */
$database_name = 'counter'; /* ----- nama database mu ------- */
/* ----- koneksi db mulai, code di bawah ini jangan di rubah ------- */
$connection = mysql_pconnect("$dbhost","$dbusername","$dbpasswd") or die ("Couldn't connect to server.");
$db = mysql_select_db("$database_name", $connection) or die("Couldn't select database.");
/* ----- koneksi database habis ------- */
/* ----- jika session "counted" belum terdaftar ------- */
if (!session_is_registered("counted")){
/* ----- maka Update cell "count" dengan menambah kan +1 ------- */
mysql_query("UPDATE counter SET count=(count + 1) WHERE count_id=1");
/* ----- daftarkan session "counted" ------- */
session_register("counted");
}
?>
Visitor:
/* ----- tampilkan nilai/value dari table "counter" kolom ke-2 yg berarti kolom "count" ------- */
$sql = mysql_query("SELECT * FROM counter LIMIT 1");
while($row = mysql_fetch_array($sql)){
echo $row[1];
}
?>
Hits:
/* ----- untuk hits, kita tidak perlu fungsi "IF" ------- */
/* ----- Update cell "hits" dengan menambah kan +1 ------- */
mysql_query("UPDATE counter SET hits=(hits + 1) WHERE count_id=1");
/* ----- tampilkan nilai/value dari table "counter" kolom ke-3 yg berarti kolom "hits" ------- */
/* ----- yang telah di update dari dari proses di atas ------- */
$sql = mysql_query("SELECT * FROM counter LIMIT 1");
while($row = mysql_fetch_array($sql)){
echo $row[2];
}
?>
Membuat guestbook dengan MySQL
[Tutorial] Simple PHP-MySql GuestBook
Title : Basic PHP - MySql Guest Book
Software : PHP, PHP supported Web server, MySql database
OS : Windows (2000) -- Optional
Level : Basic
Ok, It's Scripting Time....
Guest book merupakan hal dasar yang kita pelajari pada saat kita belajar membuat web dengan PHP server side script. Berawal dari guest book ini, bisa kita kembangkan menjadi shout box, aplikasi chatting, blog engine, dll.
Untuk mempersingkat saya asumsikan kalian telah mempunyai / mengintsall web server yang support PHP ( bisa IIS, tapi lebih umum menggunakan Apache). dan juga kalian telah menginstall MySql database (akan lebih mudah jika kalian juga memasang PHPmyadmin untuk mempermudah administrasi database MySql
1.
Pertama buat database pada Mysql kalian, dan table untuk menyimpan data2 buku tamu kita.
Kita bikin tabel yang simple (nama tabel = bk_tm)
Quote:
CREATE TABLE bk_tm (
ID bigint(20) NOT NULL auto_increment, nama varchar(35) NOT NULL default '', email varchar(35) NOT NULL default '', lokasi varchar(30) NOT NULL default '', komentar longblob NOT NULL, tgl_input varchar(40) NOT NULL default '', yim varchar(20) NOT NULL default '', ip_add varchar(255) NOT NULL default '', <<> |
Sesudah database dan tabel terbentuk, kita bikin koneksi ke database dengan script PHP (koneksi.php). Lebih baik dalam file terpisah, sehingga bisa kita gunakan berulang2.
Quote:
|
Sekarang saatnya kita bikin halaman untuk form inputan buku tamu (input.php)
Quote:
|
";
print " "; } else if (isset($_POST['submit'])) { $vnama=$_POST['fnama']; $vlokasi=$_POST['flokasi']; $vemail=$_POST['femail']; $vyim=$_POST['fyim']; $vkomentar=$_POST['fkomentar']; // baris dibawah ini untuk mengecek jika field nama dan komentar masih kosong if(!$name || !$comment) { print "Wooii... Nama dan komentar di isi donk, niat ngisi buku tamu gak sih.... "; } else { $vip_asal=$_SERVER["REMOTE_ADDR"]; //mendapatkan ip address pengisi buku tamu $sekarang=time(); $vtgl=date("D M d, Y H:i:s",$sekarang); $kueri_isi="INSERT INTO bk_tm(nama, lokasi, email, komentar, tgl_input, yim, ip_add) VALUES('$vnama','$vlokasi','$vemail','$vkomentar', '$vtgl','$yim','$vip_asal')"; mysql_query($kueri_isi); print "Terima kasih telah mengisi buku tamu, harap tunggu sebentar "; } } } ?> |
Ok, It's show time........Sekarang saatnya menampilkan (index.php)
Quote:
";
print "
";
$vkueri="SELECT * from bk_tm order by ID DESC"; //kueri semua isi tabel bk_tm, urut postingan terakhir $eksekusi=mysql_query($vkueri) or die(mysql_error()); print " | ";
";
print " print " |
print "";
while($tampil=mysql_fetch_array($eksekusi))
{
$eksekusi[komentar]=htmlspecialchars($eksekusi[komentar]);
$eksekusi[nama]=htmlspecialchars($eksekusi[nama]);
$eksekusi[lokasi]=htmlspecialchars($eksekusi[lokasi]);
print "";
print "$eksekusi[tgl_input]
";
print "$eksekusi[nama]
";
print "$eksekusi[lokasi]
";
if($eksekusi[email])
{
print "e-mail
";
}
if($gbvalues[yim])
{
print "YM ID : '$eksekusi[yim]' ";
}
print "";
print "";
$tampil_koment = wordwrap( $eksekusi[komentar], 19, "\n", 1);
print "$tampil_koment";
print "";
print "";
?>
Membuat Guest Book dengan PHP
Guest Book sederhana dengan Flex (PHP)
Tentunya rekan rekan sudah mengetahui apa itu Guest Book bukan ?. Biasanya Guest book pada halaman web berguna untuk menyimpan komentar dari para pengunjung web. Pengunjung dapat menuliskan nama kemudian komentarnya selanjutnya aplikasi guest book ini akan menyimpan data tersebut ke server dan menampilkannya di halaman web. Jadi secara garis besar guest book ini mempunyai 2 fungsi utama :
Secara garis besar pembuatan aplikasi guest book dibagi atas 4 tahap yaitu :Tentunya rekan rekan sudah mengetahui apa itu Guest Book bukan ?. Biasanya Guest book pada halaman web berguna untuk menyimpan komentar dari para pengunjung web. Pengunjung dapat menuliskan nama kemudian komentarnya selanjutnya aplikasi guest book ini akan menyimpan data tersebut ke server dan menampilkannya di halaman web. Jadi secara garis besar guest book ini mempunyai 2 fungsi utama :
- Fungsi untuk input komentar ( nama pengunjung dan komentarnya )
- Fungsi untuk menampilkan komentar yang ada dalam format tabel atau list
- MySQL berfungsi untuk penyimpanan database, tentunya rekan rekan bisa menggunakan teknologi yang lain seperti Sql server,Oracle, dlsb. Dalam contoh ini kita coba pakai MySQL
- PHP berfungsi sebagai back end dan bertanggung jawab untuk :
- Melakukan koneksi ke database
- Mengirimkan instruksi sql statement ke database (insert dan select) untuk menambah mengambil data
- Memformat hasil query (data) ke bentuk XML yang nantinya akan dibaca oleh flex. Sebagai informasi dalam contoh ini masih menggunakan XML , sebenarnya ada metode yang lebih cepat yaitu dengan remoting server menggunakan AMFPHP, cuma saat ini masih saya pelajari, mungkin di lain kesempatan akan saya bahas lagi dengan menggunakan AMFPHP.
- Flex berfungsi sebagai front end aplikasi dalam hal ini yang tampak oleh user di browser nya.
- Persiapan yang meliputi :
- Instalasi flex builder 3, bisa download versi trialnya di http://www.adobe.com, kemudian untuk lisensi versi educational (free) dapat mengunjungi http://www.flex-registration.com, lisensi ini diberikan untuk instansi pendidikan. Kita cukup memasukkan data pribadi kemudian image hasil scan kartu indentitas yang menerangkan bahwa kita bekerja di instansi pendidikan (bisa kartu NIM, kartu pegawai atau surat dari sekolah), seminggu kemudian kode lisensi akan dikirim lewat email.
- Instalasi XAMPP , bisa didownload di http://www.xampp.com
3. Pembuatan script PHP
4. Pembuatan interface dengan Flex
Pembuatan Database
Kita masuk ke tahap kedua yaitu pembuatan database. Database yang akan kita buat hanya terdiri dari satu table saja yaitu kita namakan saja komentar yang terdiri dari 4 field yaitu id, nama,tgl dan komentar. Untuk melakukan hal ini :
- Buka web browser, lalu ketikkan alamat http://localhost atau http://127.0.0.1
- Masuk ke menu PhpMyadmin
- Buat database baru dengan nama maslo (namanya terserah rekan rekan)
- Kemudian buat tabel baru dengan nama kometar dengan struktur sebagai berikut :
- ID : int , auto increment, primary key
- Nama : varchar (255)
- Komen : longtext
- Tgl : varchar(99)
CREATE TABLE komentar (
`ID` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`nama` VARCHAR( 255 ) NOT NULL ,
`komen` LONGTEXT NOT NULL , `tgl` VARCHAR( 99 ) NOT NULL
) ENGINE = MYISAM ;
- Untuk keperluan pengetesan, isi tabel komentar dengan beberapa record
- Berikut contoh statement untuk insert record. Kita bisa melakukannya dari menu insert pada PhpMyadmin.
VALUES (
NULL , 'shelo', 'hai rekan rekan mari sama sama kita belajar flex',’31 may 2008’
) , (
NULL , 'abahrama', 'fokus pada kekuatan siasati kelemahan', ’31 may 2008’
);
Pembuatan Script PHP
Tahap selanjutnya adalah membuat script php untuk koneksi dan manipulasi database. Ada 3 script php yang akan kita buat yaitu :
- Koneksi.php fungsinya adalah untuk koneksi dengan database. Scriptnya sangat sederhana yaitu sbb :
- Select_komentar.php fungsinya untuk mengambil isi dari tabel komentar dan memformatnya dalam bentuk XML. Scriptnya sebagai berikut :
\r\n";
echo "\t\r\n"; \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo "\t
while ($dataku=mysql_fetch_array($result))
{
echo "\t\r\n"; \r\n";
echo"\t\t".$dataku[id]." \r\n";
echo"\t\t".$dataku[nama]." \r\n";
echo"\t\t\r\n";
echo"\t\t\r\n";
echo "\t
}
echo "\t\r\n"; \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo "\t
echo "\r\n";
?>
- Penjelasan script diatas :
include 'koneksi.php';
perintah ini berfungsi untuk memanggil script koneksi.php untuk melakukan koneksi ke database
$result = mysql_query(stripslashes("select id,nama,komen,tgl from komentar order by id desc "));
perintah ini mengirimkan sql statement yaitu perintah untuk mengambil isi tabel. Saya tidak akan membahas lebih mendalam mengenai sql statemen karena fokus kita bukan kesitu. Namun bagi rekan rekan yang ingin mempelajari sql statemen bisa cari tutorialnya di internet.
echo "\r\n";
perintah ini berfungsi untuk mencetak kalimatsebagai header dari struktur XML kita. Tentu saja kata “recordset” dapat diganti dengan kata yang lain terserah rekan rekan.
echo "\t\r\n"; \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo"\t\teof \r\n";
echo "\t
baris ini berfungsi untuk mencetak data kosong (dummy data) ( lho koq... mungkin membingungkan). Berdasarkan pengalaman saya, jika ternyata tabel yang kita select tidak ada isinya (kosong) maka xml yang kita hasilkan juga akan kosong, nah hal ini membuat aplikasi flex kita akan error, nah untuk men siasati nya kita taruh data kosong pada permulaan struktur xml kita (bingung kan ...???). Ini hanya akal akalan saya saja, mungkin ada cara lain yang lebih cerdik dari ini. Jika rekan rekan ada yang punya cara lain , saya akan sangat senang jika diberitahu.
while ($dataku=mysql_fetch_array($result))
{ echo "\t\r\n"; \r\n"; }
echo"\t\t".$dataku[id]." \r\n";
echo"\t\t".$dataku[nama]." \r\n";
echo"\t\t\r\n";
echo"\t\t\r\n";
echo "\t
baris ini berfungsi untuk melakukan perulangan record by record dan menuliskan ke dalam struktur XML. Untuk mengambil isi record menggunakan perintah .$dataku[id]. [id] adalah nama field. Yang aneh disini adalah statement “
1
shelo
eof
eof
eof
eof
eof
- Nah jika sudah tampil seperti diatas , selamat untuk anda karena telah satu langkah lebih dekat dalam mengenal flex yaitu berkenalan dengan XML.
- Script yang ketiga adalah insert_komentar.php isinya sebagai berikut :
include 'koneksi.php';
$result = mysql_query(stripslashes("insert into komentar(nama,tgl,komen) values('".$_POST ["nama"]."','".$_POST["tgl"]."','".$_POST["komen"]."')"));
?>
penjelasannya :
include 'koneksi.php'
perintah ini berfungsi untuk memanggil script koneksi.php untuk melakukan koneksi ke database
$result = mysql_query(stripslashes("insert into komentar(nama,tgl,komen) values('".$_POST ["nama"]."','".$_POST["tgl"]."','".$_POST["komen"]."')"));
perintah ini untuk mengirimkan sql statement insert atau menambahkan record baru ke dalam table. Yang perlu diperhatikan disini perintah $_POST ["nama"] . perintah tersebut untuk mengambil parameter yang dikirim oleh aplikasi (dalam hal ini flex) yang perlu diingat adalah nama parameter nya harus sama persis (case sensitif) antara yang ada di script php dengan yang ada di flex (nanti kita akan bahas).
Tahapan terakhir dalam pembuatan guest book adalah mendesain front end dengan Flex. Ada 2 file mxml yang harus kita buat :
- Simple_gbook.mxml : ini adalah file utama aplikasi kita
- Comment_renderer.mxml : ini adalah component yang digunakan sebagai renderer pada control tile list yang berfungsi untuk menampilkan data.
- Pilih File | new | Flex project
- Isi project name , misalnya simple_gbook.
- Secara default flex builder akan menyimpan project yang kita buat di folder my documents\Fex builder 3. namun jika kita mau menyimpan di tempat lain , un check option use default location, kemudian browse folder yang kita kehendaki.
- Klik next
- Selanjutnya kita diminta men set output folder. Secara default output folder akan dibuat di dalam folder project kita. Karena project ini menggunakan php maka output folder harus di set ke dalam folder program files/xampp/htdocs.
- Klik browse, pilih folder c:\program filed\xampp\htdocs. Buatlah folder baru dengan cara klik tombol make new folder. Namakan folder baru tersebut misalnya gbook.
- Untuk menjalankan project kita setelah dibuild, harus dari browser, kemudian ketik alamat web server kita yaitu http://127.0.0.1/gbook/simple_gbook.html, jangan jalankan program dari menu run project karena saya jamin pasti akan error.
Rabu, 10 Desember 2008
COUNTER
Membuat Counter Sederhana dengan PHP
Pada artikel kali ini, aku akan men-share sedikit script PHP untuk membuat counter sederhana seperti yang terdapat di bagian footer website ini. Bagi kamu yang udah ngerasa expert, sebaiknya berhenti membaca sekarang juga, karna dari judulnya, kamu seharusnya tau bahwa kita cuma mo bikin counter simple. Cara kerja counter ini kurang lebih kayak gini: halaman utama dibuka->input ke database->Output berupa jumlah records dari table yang dijadikan counter. OK, lets do this...
Pertama, buatlah table dengan nama counter pada database MySQL kamu dengan field sebagai berikut:
a. ip
b. user_agent
c. tanggal
Sekarang, tambahkan script berikut pada halaman utama website kamu. Ingat, tempatkan script ini di bagian paling atas sebelum tag
$ip=getenv(remote_addr);
$date=getdate(date("U"));
$day=$date[mday];
$month=$date[month];$year=$date[year];
if (!isset($_COOKIE["visitor"]))
{
setcookie("visitor", "$ip", time() +3600);
mysql_connect("localhost", "user",
"password"); //sesuaikan host, user, dan password-nya !
mysql_select_db("nama_db") or die(mysql_error
()); //sesuaikan nama database-nya
mysql_query("INSERT INTO counter(ip, user_agent,
tanggal) VALUES('$ip', '$_SERVER[HTTP_USER_AGENT]',
'$day/$month/$year')");
}
?>
Pada code di atas, saat pertama kalo diakses halaman website kita akan membuat cookies dengan nama visitor yang isinya IP address dari visitor kita. Kalo cookies belom diset, maka record table Counter akan ditambah satu.
Untuk mendapatkan jumlah pengunjung, kita tinggal menghitung berapa jumlah records dari table Counter, gunakan code berikut:
$qhit=mysql_query("SELECT * FROM counter");
$hit=mysql_num_rows($qhit);
echo "
Kamu adalah pengunjung ke: $hit
";
?>
Sekarang, kamu tinggal meletakkan code di atas untuk menampilkan berapa jumlah pengunjung website kamu.
Semoga bermanfaat dan mohon dimaafkan kalo ada kesalahan.
Pada artikel kali ini, aku akan men-share sedikit script PHP untuk membuat counter sederhana seperti yang terdapat di bagian footer website ini. Bagi kamu yang udah ngerasa expert, sebaiknya berhenti membaca sekarang juga, karna dari judulnya, kamu seharusnya tau bahwa kita cuma mo bikin counter simple. Cara kerja counter ini kurang lebih kayak gini: halaman utama dibuka->input ke database->Output berupa jumlah records dari table yang dijadikan counter. OK, lets do this...
Pertama, buatlah table dengan nama counter pada database MySQL kamu dengan field sebagai berikut:
a. ip
b. user_agent
c. tanggal
Sekarang, tambahkan script berikut pada halaman utama website kamu. Ingat, tempatkan script ini di bagian paling atas sebelum tag
$ip=getenv(remote_addr);
$date=getdate(date("U"));
$day=$date[mday];
$month=$date[month];$year=$date[year];
if (!isset($_COOKIE["visitor"]))
{
setcookie("visitor", "$ip", time() +3600);
mysql_connect("localhost", "user",
"password"); //sesuaikan host, user, dan password-nya !
mysql_select_db("nama_db") or die(mysql_error
()); //sesuaikan nama database-nya
mysql_query("INSERT INTO counter(ip, user_agent,
tanggal) VALUES('$ip', '$_SERVER[HTTP_USER_AGENT]',
'$day/$month/$year')");
}
?>
Pada code di atas, saat pertama kalo diakses halaman website kita akan membuat cookies dengan nama visitor yang isinya IP address dari visitor kita. Kalo cookies belom diset, maka record table Counter akan ditambah satu.
Untuk mendapatkan jumlah pengunjung, kita tinggal menghitung berapa jumlah records dari table Counter, gunakan code berikut:
$qhit=mysql_query("SELECT * FROM counter");
$hit=mysql_num_rows($qhit);
echo "
Kamu adalah pengunjung ke: $hit
";
?>
Sekarang, kamu tinggal meletakkan code di atas untuk menampilkan berapa jumlah pengunjung website kamu.
Semoga bermanfaat dan mohon dimaafkan kalo ada kesalahan.
Langganan:
Postingan (Atom)