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>