PHP - Çerezler
Çerezler, istemci bilgisayarda saklanan metin dosyalarıdır ve kullanım izleme amacıyla tutulur. PHP, HTTP tanımlama bilgilerini şeffaf bir şekilde destekler.
Geri dönen kullanıcıları belirlemenin üç adımı vardır:
Sunucu komut dosyası, tarayıcıya bir dizi çerez gönderir. Örneğin isim, yaş veya kimlik numarası vb.
Tarayıcı, bu bilgileri ileride kullanılmak üzere yerel makinede depolar.
Tarayıcı bir dahaki sefere web sunucusuna herhangi bir istek gönderdiğinde, bu tanımlama bilgilerini sunucuya gönderir ve sunucu, kullanıcıyı tanımlamak için bu bilgileri kullanır.
Bu bölüm size tanımlama bilgilerini nasıl ayarlayacağınızı, bunlara nasıl erişeceğinizi ve nasıl sileceğinizi öğretecektir.
Bir Çerezin Anatomisi
Çerezler genellikle bir HTTP başlığında ayarlanır (bununla birlikte JavaScript, doğrudan bir tarayıcıya da bir çerez ayarlayabilir). Bir tanımlama bilgisini ayarlayan bir PHP betiği şuna benzer başlıklar gönderebilir -
HTTP/1.1 200 OK
Date: Fri, 04 Feb 2000 21:03:38 GMT
Server: Apache/1.3.9 (UNIX) PHP/4.0b3
Set-Cookie: name=xyz; expires=Friday, 04-Feb-07 22:03:38 GMT;
path=/; domain=tutorialspoint.com
Connection: close
Content-Type: text/html
Gördüğünüz gibi, Set-Cookie başlığı bir ad-değer çifti, bir GMT tarihi, bir yol ve bir etki alanı içerir. Ad ve değer URL olarak kodlanacaktır. Son kullanma tarihi alanı, tarayıcıya verilen saat ve tarihten sonra çerezi "unutması" için bir talimattır.
Tarayıcı tanımlama bilgilerini depolayacak şekilde yapılandırılmışsa, bu bilgileri son kullanma tarihine kadar saklayacaktır. Kullanıcı, tarayıcıyı çerezin yolu ve etki alanıyla eşleşen herhangi bir sayfaya yönlendirirse, çerezi sunucuya yeniden gönderir. Tarayıcının başlıkları şuna benzer şekilde görünebilir -
GET / HTTP/1.0
Connection: Keep-Alive
User-Agent: Mozilla/4.6 (X11; I; Linux 2.2.6-15apmac ppc)
Host: zink.demon.co.uk:1126
Accept: image/gif, */*
Accept-Encoding: gzip
Accept-Language: en
Accept-Charset: iso-8859-1,*,utf-8
Cookie: name=xyz
Bir PHP betiği daha sonra tüm tanımlama bilgisi adlarını ve değerlerini tutan çevresel değişkenler $ _COOKIE veya $ HTTP_COOKIE_VARS [] içindeki tanımlama bilgisine erişebilir. Yukarıdaki tanımlama bilgisine $ HTTP_COOKIE_VARS ["ad"] kullanılarak erişilebilir.
PHP ile Çerezleri Ayarlama
PHP sağlandı setcookie()tanımlama bilgisi ayarlama işlevi. Bu işlev en fazla altı argüman gerektirir ve <html> etiketinden önce çağrılmalıdır. Her çerez için bu işlevin ayrı olarak çağrılması gerekir.
setcookie(name, value, expire, path, domain, security);
İşte tüm argümanların detayı -
Name- Bu, tanımlama bilgisinin adını belirler ve HTTP_COOKIE_VARS adlı bir ortam değişkeninde saklanır. Bu değişken, çerezlere erişilirken kullanılır.
Value - Bu, adlandırılmış değişkenin değerini ayarlar ve gerçekten depolamak istediğiniz içeriktir.
Expiry- Bu, 1 Ocak 1970 00:00:00 GMT'den bu yana saniye cinsinden gelecekteki bir saati belirtir. Bu saatten sonra çerez erişilemez hale gelecektir. Bu parametre ayarlanmazsa, Web Tarayıcısı kapatıldığında tanımlama bilgisi otomatik olarak sona erer.
Path- Bu, çerezin geçerli olduğu dizinleri belirtir. Tek bir eğik çizgi karakteri, tanımlama bilgisinin tüm dizinler için geçerli olmasına izin verir.
Domain- Bu, çok büyük alanlarda alan adını belirtmek için kullanılabilir ve geçerli olması için en az iki nokta içermelidir. Tüm çerezler yalnızca onları oluşturan ana bilgisayar ve etki alanı için geçerlidir.
Security - Bu, tanımlama bilgisinin yalnızca HTTPS kullanılarak güvenli aktarımla gönderilmesi gerektiğini belirtmek için 1 olarak ayarlanabilir, aksi takdirde 0 olarak ayarlanır; bu, tanımlama bilgisinin normal HTTP ile gönderilebileceği anlamına gelir.
Aşağıdaki örnek iki çerez oluşturacaktır name ve age bu çerezlerin süresi bir saat sonra dolacaktır.
<?php
setcookie("name", "John Watkin", time()+3600, "/","", 0);
setcookie("age", "36", time()+3600, "/", "", 0);
?>
<html>
<head>
<title>Setting Cookies with PHP</title>
</head>
<body>
<?php echo "Set Cookies"?>
</body>
</html>
PHP ile Çerezlere Erişim
PHP, tanımlama bilgilerine erişmek için birçok yol sağlar. En basit yol, $ _COOKIE veya $ HTTP_COOKIE_VARS değişkenlerini kullanmaktır. Aşağıdaki örnek, yukarıdaki örnekte ayarlanan tüm çerezlere erişecektir.
<html>
<head>
<title>Accessing Cookies with PHP</title>
</head>
<body>
<?php
echo $_COOKIE["name"]. "<br />";
/* is equivalent to */
echo $HTTP_COOKIE_VARS["name"]. "<br />";
echo $_COOKIE["age"] . "<br />";
/* is equivalent to */
echo $HTTP_COOKIE_VARS["age"] . "<br />";
?>
</body>
</html>
Kullanabilirsiniz isset() bir tanımlama bilgisinin ayarlanıp ayarlanmadığını kontrol etme işlevi.
<html>
<head>
<title>Accessing Cookies with PHP</title>
</head>
<body>
<?php
if( isset($_COOKIE["name"]))
echo "Welcome " . $_COOKIE["name"] . "<br />";
else
echo "Sorry... Not recognized" . "<br />";
?>
</body>
</html>
Çerezi PHP ile Silme
Resmi olarak, bir çerezi silmek için setcookie () 'yi yalnızca isim bağımsız değişkeniyle çağırmalısınız, ancak bu her zaman iyi çalışmaz ve buna güvenilmemelidir.
Çerezi, süresi dolmuş bir tarihe ayarlamak en güvenlisidir -
<?php
setcookie( "name", "", time()- 60, "/","", 0);
setcookie( "age", "", time()- 60, "/","", 0);
?>
<html>
<head>
<title>Deleting Cookies with PHP</title>
</head>
<body>
<?php echo "Deleted Cookies" ?>
</body>
</html>