OW Debug - Notice
Message: Trying to access array offset on value of type null
File: /home/romarekl/public_html/sosyallift.com/ow_plugins/forum/controllers/topic.php
Line: 136
session Forum | Sosyallift©
Loading...
 
tr
Servet Yılmaz Admin
Servet Yılmaz Şubat 13 '18

Php ile tarayıcı kapansa da oturumun devam etmesi için ne yapmak lazım

Paylaş:
Whordark
Whordark Şubat 15 '18
session_start()

Bu fonksiyonu oturumları kullanıcağımız her sayfanın başında belirtmeliyiz. Bu fonksiyon kullanıcı ilk defa giriyorsa kullanıcı için serverda bir dosya yaratır ve kullanıma hazırlar. Eğer daha önce girmişse onu kullanmaya hazırlar sadece. Her kullanıcı için uzun bir kod üretir. Bu kod sayılardan ve harflerden oluşur.

session_start();

Eğer php.ini dosyasında otomatik olarak oturum başlatma seçeneği aktif değilse bu işlemi yapmak zorundayız. Oturum fonksiyonları eğer bir oturum açılmamışsa (session_start) hata verecektir. Her sayfanızın başında bu fonksiyonu çağırarak bu sorunu rahatlikla çözebilirsiniz. Öneri olarak, her sayfanızda çalıştırdığınız (include) sayfanız varsa bu sayfaya ekleyin.

session_register()

Sunucuda sizin için açılmış olan dosyaya bir değer yazar. Aynı cookie gibi işler ancak dosyalar zamana göre silinmez, kullanıcı oturumunu kapatınca silinirler. Kullanıcının oturum kapatması ise, o andaki tarayıcı programının oturumu kapatması ile olur. Çoğu tarayıcı, oturumunu tüm pencereleri kapandığı zaman kapatmış olur.

$isim = "nazim";

session_register("isim");

$isim değerini nazim olarak atayıp sonra da oturumumuza kaydettik.

Oturum değişkenleri ve değerleri cookie’ler gibi bir dizide tutulur.

$_SESSION ($HTTP_SESSION_VARS) dizisidir. Bu dizinin normal bir diziden hiçbir farkı yoktur. Atamaları da buna benzer bir teknik ile yapabiliriz.

session_register("isim");

$_SESSION["isim"] = "mfyz";

Önce $isim diye bir oturum bilgisi yaratıp sonra bilgiyi güncelledik.

session_is_registered()

Bir oturumun kayıtlı olup olmadığını veya bir oturum değişkeninin kaydedilip edilmediğini öğrenmemize yaran bir fonksiyondur.

if( session_is_registered("isim") ){

echo "isim oturumu kayıtlı";

}

else{

echo "isim oturumu kayıtlı degil";

}

“isim” oturumunun kayıtlı olup olmadığına bakar.

session_unregister()

Kaydettiğiniz bir oturum değişkenini silmek için kullanılır.

session_unregister("isim");

Daha önce oluşturduğumuz isim adlı oturum bilgisini siler.

session_destroy()

Kayıtlı olan tüm oturum bilgilerini yok eder.

session_destroy();

Geçerli olan tüm oturum verilerini yok eder.

Şimdi ufak bir uygulama yapalım :

Giriş/Çıkış İşlemi

Günümüzde neredeyse her sitede bi üyelik sistemi var (forumu veya interaktif hizmeti olmamasina rağmen), bence çoğu site için gereksiz.
Basitçe bir giriş/çıkış sistemi yapalım. Bu iş için giris.php, cikis.php, index.php dosyalarimiz olacak.

<form action="giris.php" method="post">

<input type="text" name="ad">

<input type="submit" value="Giris">

</form>

Basit bir index sayfamız var. Burada giriş formu var. Bunu sitenizin istediğiniz köşesine koyabilirsiniz.
Ziyaretçi adını girip Giris’e tıkladığı zaman giris.php dosyasına post edilecek.

<?php

// bilgiyi alalim

$ad = $_POST["ad"];

// oturum baslatalim

session_start();

// giris kontorl degiskeni tanimlayalim

$giris = true;

// ve degiskenleri kaydedelim

session_register('ad');

session_register('giris');

// giris tamamlandi, anasayfaya gonderelim

header("location:index.php");

?>

Şimdi ansayfamizi gelistirmemiz gerek. Giriş yapmış ziyaretçilere hitap eden kısımları küçük bir sargı ile çevreleyeceğiz.

<?

// oturumu baslatalim

sesion_start();

// giris bilgilerini alalim.

$giris = $_SESSION["giris"];

$ad = $_SESSION["ad"];

// giris kontorlu yapalim

// giris yapilmis ise $giris true olmali

if( $giris ){

// giris yapilmis hosgeldin..

print 'Hoşgeldin ' . $ad . '<br>

<a href="cikis.php">Çıkış</a>';

}

else{

// giris yapilmamis giris formu yazdiralim

print '<form action="giris.php" method="post">

<input type="text" name="ad">

<input type="submit" value="Giris">

</form>';

}

?>

İşte oldu, anasayfamız giriş kontorlu yaparak kullanıcı daha önce giriş yapmışsa tanıyor.

Çıkış dosyamız ise çok basit. oturumu öldürecek.

<?

// oturumu baslatalim

session_start();

// oturumu oldurelim

session_destroy();

// ansayfaya gidelim

header("location:index.php");

?>