ES6 - Çerezler

Web Tarayıcıları ve Sunucuları iletişim kurmak için HTTP protokolünü kullanır. HTTP durum bilgisiz bir protokoldür, yani istemcinin verilerini istemci tarafından yapılan birden çok istekte tutmaz. İstemci ile sunucu arasındaki bu eksiksiz istek-yanıt döngüsü, birsession. Çerezler, bir kullanıcının oturumuna ilişkin verileri depolamak için tarayıcılar tarafından kullanılan varsayılan mekanizmadır.

Nasıl çalışır?

Sunucunuz bazı verileri ziyaretçinin tarayıcısına çerez şeklinde gönderir. Tarayıcı çerezi kabul edebilir. Varsa, ziyaretçinin sabit diskinde düz metin kaydı olarak saklanır. Şimdi, ziyaretçi sitenizdeki başka bir sayfaya ulaştığında, tarayıcı aynı çerezi geri alınması için sunucuya gönderir. Alındıktan sonra, sunucunuz daha önce nelerin depolandığını bilir / hatırlar.

Çerezler, 5 değişken uzunluklu alanın düz metin veri kaydıdır.

  • Expires- Çerezin süresinin dolacağı tarih. Bu boşsa, çerez, ziyaretçi tarayıcıdan çıktığında sona erecektir.

  • Domain - Sitenizin alan adı.

  • Path- Tanımlama bilgisini ayarlayan dizine veya web sayfasına giden yol. Çerezi herhangi bir dizinden veya sayfadan almak istiyorsanız bu boş olabilir.

  • Secure- Bu alan "güvenli" kelimesini içeriyorsa, çerez yalnızca güvenli bir sunucu ile alınabilir. Bu alan boşsa, böyle bir kısıtlama yoktur.

  • Name = Value - Çerezler, anahtar-değer çiftleri şeklinde ayarlanır ve alınır.

Çerezler başlangıçta CGI programlama için tasarlanmıştır. Bir tanımlama bilgisinde bulunan veriler web tarayıcısı ile web sunucusu arasında otomatik olarak iletilir, böylece sunucudaki CGI komut dosyaları istemci tarafında depolanan tanımlama bilgisi değerlerini okuyabilir ve yazabilir.

JavaScript, aynı zamanda Document nesnesinin cookie özelliğini kullanarak tanımlama bilgilerini de işleyebilir. JavaScript, mevcut web sayfası için geçerli olan tanımlama bilgilerini okuyabilir, oluşturabilir, değiştirebilir ve silebilir.

Çerezlerin Saklanması

Bir çerez oluşturmanın en basit yolu, bir dize değeri atamaktır. document.cookie buna benzeyen nesne.

"document.cookie = "key1 = value1; key2 = value2; expires = date";

Burada, "sona erme" özelliği isteğe bağlıdır. Bu özniteliğe geçerli bir tarih veya saat sağlarsanız, çerezin süresi belirtilen tarihte veya saatte sona erecek ve bundan sonra çerezlerin değerine erişilemeyecektir.

Note- Çerez değerleri noktalı virgül, virgül veya boşluk içeremez. Bu nedenle JavaScript'i kullanmak isteyebilirsiniz.escape()değeri tanımlama bilgisine kaydetmeden önce kodlamak için işlev. Bunu yaparsanız, ilgili olanı da kullanmanız gerekecektir.unescape() çerez değerini okuduğunuzda işlev görür.

Misal

<html> 
   <head> 
      <script type = "text/javascript">  
         function WriteCookie() {  
            if( document.myform.customer.value == "" ){  
               alert ("Enter some value!");  
               return;  
            }  
            cookievalue =  escape(document.myform.customer.value) + ";";  
            document.cookie = "name = " + cookievalue;  
            document.write ("Setting Cookies : " + "name = " + cookievalue );  
         }  
      </script> 
   </head> 
      
   <body> 
      <form name = "myform" action = ""> 
         Enter name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set" onclick = "WriteCookie();"/> 
      </form> 
   </body> 
</html>

Yukarıdaki kod başarılı bir şekilde yürütüldüğünde aşağıdaki çıktı görüntülenir.

Artık makinenizin adı adında bir tanımlama bilgisi var. Virgülle ayrılmış birden çok anahtar = değer çifti kullanarak birden çok çerez ayarlayabilirsiniz.

Çerezleri Okumak

Bir tanımlama bilgisini okumak, bir tanımlama bilgisi yazmak kadar basittir, çünkü tanımlama bilgisinin değeri document.cookienesne tanımlama bilgisidir. Böylece bu dizeyi çereze erişmek istediğinizde kullanabilirsiniz. document.cookie string, noktalı virgülle ayrılmış ad = değer çiftlerinin bir listesini tutar; burada ad, bir tanımlama bilgisinin adı ve değer, dize değeridir.

Dizeleri kullanabilirsiniz ' split() aşağıdaki örnekte gösterildiği gibi bir dizeyi anahtar ve değerlere ayırma işlevi.

Misal

<html> 
   <head> 
      <script type = "text/javascript"> 
         function ReadCookie() {  
            var allcookies  =  document.cookie;  
            document.write ("All Cookies : " + allcookies ); 
         } 
         // Get all the cookies pairs in an array  
         cookiearray = allcookies.split(';');  
         
         // Now take key value pair out of this array  
         for(var i = 0; i<cookiearray.length; i++) {  
            name  =  cookiearray[i].split('=')[0];  
            value = cookiearray[i].split('=')[1];  
            document.write ("Key is : " + name + " and Value is : " + value); 
         }  
      </script> 
   </head> 

   <body> 
      <form name = "myform" action = ""> 
         <p> click the following button and see the result:</p> 
         <input type = "button" value = "Get Cookie" onclick = "ReadCookie()"/> 
      </form> 
   </body> 
</html>

Note - Burada uzunluk, bir dizinin uzunluğunu döndüren Array sınıfının bir yöntemidir.

Makinenizde zaten ayarlanmış başka çerezler olabilir. Yukarıdaki kod, makinenizde ayarlanan tüm çerezleri gösterecektir.

Yukarıdaki kod başarılı bir şekilde yürütüldüğünde aşağıdaki çıktı görüntülenir.

Çerezlerin Son Kullanma Tarihini Ayarlama

Bir son kullanma tarihi belirleyerek ve son kullanma tarihini çerez içine kaydederek bir çerezin ömrünü mevcut tarayıcı oturumunun ötesine uzatabilirsiniz. Bu, 'sona erme' özniteliğini bir tarih ve saate ayarlayarak yapılabilir. Aşağıdaki örnek, bir çerezin sona erme tarihinin nasıl 1 ay uzatılacağını göstermektedir.

Misal

<html> 
   <head> 
      <script type = "text/javascript"> 
         function WriteCookie() {  
            var now = new Date();  
            now.setMonth( now.getMonth() + 1 );  
            cookievalue = escape(document.myform.customer.value) + ";"  
            document.cookie = "name = " + cookievalue;  
            document.cookie = "expires = " + now.toUTCString() + ";"  
            document.write ("Setting Cookies : " + "name = " + cookievalue );  
         } 
      </script> 
   </head> 

   <body> 
      <form name = "formname" action = ""> 
         Enter Cookie Name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/> 
      </form> 
   </body> 
</html>

Yukarıdaki kod başarılı bir şekilde yürütüldüğünde aşağıdaki çıktı görüntülenir.

Bir Çerezi Silme

Bazen bir çerezi silmek isteyebilirsiniz, böylece sonraki çerez okuma girişimleri hiçbir sonuç vermez. Bunu yapmak için, son kullanma tarihini geçmiş bir zamana ayarlamanız yeterlidir. Aşağıdaki örnek, son kullanma tarihini geçerli tarihten bir ay sonrasına ayarlayarak bir çerezin nasıl silineceğini gösterir.

Misal

<html> 
   <head> 
      <script type = "text/javascript"> 
         function WriteCookie() {  
            var now = new Date();  
            now.setMonth( now.getMonth() - 1 );  
            cookievalue = escape(document.myform.customer.value) + ";" 
            document.cookie = "name=" + cookievalue;  
            document.cookie = "expires = " + now.toUTCString() + ";"  
            document.write("Setting Cookies : " + "name = " + cookievalue );  
         }  
      </script> 
   </head> 

   <body> 
      <form name = "formname" action = ""> 
         Enter Cookie Name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/> 
      </form> 
   </body> 
</html>

Yukarıdaki kod başarılı bir şekilde yürütüldüğünde aşağıdaki çıktı görüntülenir.