12 Ekim 2006, 18:35 | #1 | |
Çevrimdışı
Kullanıcıların profil bilgileri misafirlere kapatılmıştır.
IF Ticaret Sayısı: (0) | Ziyaretçi Defterimizi Kendimiz Yazalım Php ile ziyaretçi defteri yazalım.. Ziyaretçi defterimiz üç dosyadan oluşacaktır: 1) defter.php 2) defter2.php 3) veri.php Başlarken.. Ziyaretçi defteri isminin uzunluğu sizi ürkütmesin, php ve mysql manuallerini okurken, internette dolanan bir sürü php tutorialini incelerken, sıfır bilgi ile gerçekten bir şeyler yapılabileceğini öğrendim, emin olun, siz de azimle çalışarak bu işi öğrenebilirsiniz. Ayrıca, bu sayfaların hiçbirisinde sayfa düzenine vs. dikkat edilmemiştir, sadece kodlama yapılmıştır, geliştirmek size kalır.. Neler yapacağız? - Defter.php ile sitemize giren kişinin ziyaretçi defterimize görüş eklemesini sağlayacağız. - Defter2.php ile ziyaretçi defterimize görüşünü eklemiş olacak ve diğer görüşleri okuyabilecek. - Veri.php ile defter2.php'de gösterilen görüşlerin dökümünü alacağız. Önce aşağıdaki mysql sorgularını phpMyAdmin aracılığıyla çalıştırıyoruz.. CREATE DATABASE zdefter CHARACTER SET utf8 COLLATE utf8_turkish_ci; CREATE TABLE defter (isoyis text, eposta text, site text, tarih date, gorus text, primary key (isoyis)) Yukarıdaki sorguları çalıştırdıktan sonra veritabanının açıldığından ve defter tablosunun yaratıldığından emin olun.. Eğer eminseniz bir sonraki adıma geçiniz.. Bir dosya açın ve aşağıdaki kodları kopyaladıktan sonra defter.php ismiyle kaydedin: Kod: Kodu kopyalamak için üzerine çift tıklayın!
Burada, kullanıcımızın bilgisini eklemesini sağlıyoruz. "<form method="POST" action="defter2.php">" koduyla, eklenen bilginin defter2.php'ye gönderilmesi gerektiğini sunucuya iletiyoruz. Herhalde boşlukları doldurmayı beceremeyecek kadar zırcahil bir ziyaretçi değildir ziyaretçimiz.. :) Bir dosya açın ve aşağıdaki kodları kopyaladıktan sonra defter2.php ismiyle kaydedin: Kod: Kodu kopyalamak için üzerine çift tıklayın!
Yukarıda verilen kodlar ile defter.php'den gelen verileri hafızaya alıp, mysql aracılığıyla veritabanına ekliyoruz, arada bunun olmadığı da olabilir, dert etmeyelim, sabredelim, bekleyelim, sonucu görelim.. Belki de kodlarımızdan kaynaklanmıyordur. Şimdi kodları tek tek inceleyelim: $tarih = date("Y-m-d"); -> Hatırlarsanız, mysql'da tablo açarken tarih alanı da açmıştık, açtığımız bu tarih alanına tarih ekleyebilmemiz için tarih biçiminin yıl-ay-gün şeklinde olması gerek. date() fonksiyonu ile tarih bilgilerini alabiliriz. daha fazla bilgi için php manualinde date and time functions kısmını incelemelisiniz. $baglan = mysql_connect('localhost', 'kullaniciadi', 'sifre'); $dbsec = mysql_select_db('zdefter', $baglan); $baglan değişkeniyle belirtilen kullanıcı adı, şifre ve host ile mysql'a bağlanıyoruz. $dbsec değişkeniyle belirtilen veritabanını seçiyoruz. if (!$dbsec) { echo 'veritabani secilemedi: ' . mysql_error(); } kodu, sunucuya eger $dbsec değişkeni çalışmazsa (if(!$değişken) şeklindeki kodlarda baştaki ünlem işareti çalışmazsa, olmazsa anlamı taşımaktadır) yani $dbsec değişkeninde yapmak istediğimiz veritabanı seçme işlemi olmazsa, veritabanının seçilemediğini bildir ve mysql_error(); fonksiyonu ile veritabanının seçilememesinin nedenini göster anlamına gelmektedir. else { koduyla yukarıda belirttiğimiz veritabanı seçme işlemi başarıyla tamamlandıysa devam ediyoruz.. $ekle = "INSERT INTO defter VALUES('$isoyis', '$eposta', '$site', '$tarih', '$gorus')"; $sorgu = mysql_query($ekle, $baglan); $ekle değişkeni ile açmış olduğumuz "zdefter" veritabanındaki "defter" tablosuna değerlerini ekliyoruz. Buradaki INSERT INTO komutu VALUES() kısmının içerisindeki bilgileri "defter" tablosuna eklememizi sağlamakta. Values komutu değerler anlamına gelmektedir. $sorgu değişkeni ile $ekle değişkenindeki mysql sorgusunu çalıştırıyoruz. Ayrıca, buradaki $eposta, $site, $gorus değişkenleri, ziyaretçinin doldurduğu boşlukların değerlerinin POST komutu ile aldığımız verileridir. Yani görüş boşluğuna yazdıkları POST metodu ile $gorus değişkeni olarak bize iletildi. if (!$sorgu) { echo 'bilgiler eklenemedi: ' . mysql_error(); } } if(!$sorgu) kodu yukarıdaki if(!$dbsec) kodu ile aynı işlevi görmektedir, kod ve devamı, $sorgu yani veritabanına bilgi ekleme sorgusu çalışmazsa bunu bildirecek ve hatayı gösterecektir. include("veri.php"); kodu da veri.php dosyasını defter2.php sayfasında gösterecektir. include fonksiyonunun görevi, bir sayfada, başka bir sayfanın gösterilmesini sağlamaktır. Bir dosya açın ve aşağıdaki kodları kopyaladıktan sonra veri.php ismiyle kaydedin: Kod: Kodu kopyalamak için üzerine çift tıklayın!
burada fonksiyon ile çalışmamızın sebebi, bir script içerisinde birden fazla komutu (fonksiyonu) kavrayabilmemiz için. function mysqlislem() { kodu ile mysqlislem() fonksiyonunu başlatıyoruz. mysql_connect('localhost', 'root', 's') or die("mysqla bağlanamıyor.."); mysql_select_db('zdefter') or die("veritabanı seçilemiyor.."); fonksiyonları ile belirtilen hosta, belirtilen şifre ve kullanıcı adı ile bağlanıp, belirtilen veritabanını seçiyoruz. hatırlarsanız yukarıda bunları, $baglan ve $dbsec değişkenleri ile yapmıştık. burada göstermek istediğim, bu fonksiyonların değişkenler aracılığıyla veya kendi başlarına yapılabilmeleridir. yani yukarıda $baglan ve $dbsec değişkenleri ile yaptığımız işlemleri, tek başına da yapabiliyoruz. buradaki or bir bakıma, -kesinlikle böyle diyemeyiz, bu doğru olmaz- yukarıdaki if(!$baglan) ve if(!$dbsec) fonksiyonlarının görevini üstlenmekte. $sorgu = mysql_query('SELECT * FROM defter'); buradaki SELECT komutu seçmeye yarar, * işareti hepsi anlamına gelir, FROM tabloismi tabloismi'nden anlamına gelir, yani burada, defter tablosundaki bütün bilgileri seçiyoruz. while ($goster = mysql_fetch_array($sorgu)) bildiğiniz üzere while bir şey böyleyken şu işlemi yap anlamına gelmektedir. daha fazla bilgiyi php manualine bakarak alabilirsiniz. mysql_fetch_array fonksiyonu, $sorgu ile seçtiğimiz tablonun dökümünü almamızı sağlar, $goster değişkeni de buradaki her bir veriyi simgeler. echo "<b>İsim Soyisim:</b> " . $goster["isoyis"] . "<br>"; buradaki echo komutu bildiğiniz üzere, elimizdekileri göstermeye yarar. hepimiz echo "hello world"; olayına girmişizdir. hatta ben hatırlarım, hello world'den sonra echo "vay a.k"; yazmıştım. :D neyse, devam edelim, $goster['alan'] ile de mysql_fetch_array fonksiyonu ile elde ettiğimiz verileri gösteriyoruz. call_user_func(mysqlislem); ile de mysqlislem fonksiyonumuzu çalıştırıyoruz. buradaki call_user_func() fonksiyonu, php'nin içinde olmayan, coder'in kendi yazmış olduğu fonksiyonu göstermeye yarar. umarım, küçücük de olsa katkım olmuştur php bilginizin ilerlemesine.. buradaki kodları geliştirmek size kalmıştır. tasarım adına hiçbir şey olmadığını da anlamışsınızdır, amacımız kodlamak olduğu için tasarıma pek gerek duymadım. daha sonraki scriptlerde dikkat etmeye çalışırım.. ya da etmesem mi? neyse, bakarız.. :) kodlar üzerinde oynama hakkına sahipsiniz, tamamen benim emeğim olsa bile gönlünüzce üzerinde tepinebilir, yastık kavgası yapabilirsiniz veya kodlar üzerinde gitar kırabilirsiniz. hatta yönetici girişi yapıp, eklenen görüşleri düzenleme ve silme imkânınız bile olabilir ileride geliştirirseniz.. güzel de olur.. hadi bakalım.. aklınıza takılan kısımları bu başlık altında sorarsanız sevinirim, böylece birlikte geliştirmiş oluruz kendimizi. geliştiririz sanırım.. herhalde öyle olur ya.. neyse yine de sorun.. :) saygılar, sevgiler.. sizi sizden çok seven ve sizin için varolan ve hatta beni siz yarattınız diyen pek sağyın*, whalberg * megaloman herif! | |
|
Etiketler |
defterimizi, kendimiz, yazalim, ziyaretci |
Konuyu Toplam 1 Üye okuyor. (0 Kayıtlı üye ve 1 Misafir) | |
| |
Benzer Konular | ||||
Konu | Konuyu Başlatan | Forum | Cevaplar | Son Mesaj |
Canfeza - Onu Bunu Yazalım Şarkı Sözleri | Sara | A, B, C, Ç | 0 | 31 Mart 2021 19:24 |
Bir Code yazaLım bir iLk oLsun . . . | TrayN | Eggdrop, NeoStats, BNC | 16 | 28 Ocak 2010 13:46 |
Kendimiz hakkında bilmediklerimiz | Hesna | Merak Ettikleriniz | 0 | 25 Ocak 2010 18:13 |