ES6 - Cookie

Browser Web dan Server menggunakan protokol HTTP untuk berkomunikasi. HTTP adalah protokol tanpa negara, yaitu, ia tidak memelihara data klien di beberapa permintaan yang dibuat oleh klien. Siklus permintaan-respons lengkap antara klien dan server ini didefinisikan sebagai filesession. Cookie adalah mekanisme default yang digunakan oleh browser untuk menyimpan data yang berkaitan dengan sesi pengguna.

Bagaimana itu bekerja?

Server Anda mengirimkan beberapa data ke browser pengunjung dalam bentuk cookie. Browser mungkin menerima cookie. Jika ya, itu disimpan sebagai catatan teks biasa di hard drive pengunjung. Sekarang, saat pengunjung tiba di halaman lain di situs Anda, browser mengirimkan cookie yang sama ke server untuk diambil kembali. Setelah diambil, server Anda mengetahui / mengingat apa yang disimpan sebelumnya.

Cookie adalah rekaman data teks biasa dari 5 bidang dengan panjang variabel.

  • Expires- Tanggal cookie akan kedaluwarsa. Jika ini kosong, cookie akan kedaluwarsa saat pengunjung keluar dari browser.

  • Domain - Nama domain situs Anda.

  • Path- Jalur ke direktori atau halaman web yang menyetel cookie. Ini mungkin kosong, jika Anda ingin mengambil cookie dari direktori atau halaman manapun.

  • Secure- Jika bidang ini berisi kata "aman", cookie hanya dapat diambil dengan server aman. Jika bidang ini kosong, tidak ada batasan seperti itu.

  • Name = Value - Cookie disetel dan diambil dalam bentuk pasangan nilai kunci.

Cookies pada awalnya dirancang untuk pemrograman CGI. Data yang terdapat dalam cookie secara otomatis dikirim antara browser web dan server web, sehingga skrip CGI di server dapat membaca dan menulis nilai cookie yang disimpan di sisi klien.

JavaScript juga dapat memanipulasi cookie menggunakan properti cookie dari objek Dokumen. JavaScript dapat membaca, membuat, mengubah, dan menghapus cookie yang berlaku untuk halaman web saat ini.

Menyimpan Cookies

Cara termudah untuk membuat cookie adalah dengan menetapkan nilai string ke document.cookie objek, yang terlihat seperti ini.

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

Di sini, atribut 'expires' adalah opsional. Jika Anda memberikan atribut ini dengan tanggal atau waktu yang valid, cookie akan kedaluwarsa pada tanggal atau waktu tertentu dan setelah itu, nilai cookie tidak akan dapat diakses.

Note- Nilai cookie tidak boleh menyertakan titik koma, koma, atau spasi. Untuk alasan ini, Anda mungkin ingin menggunakan JavaScriptescape()berfungsi untuk menyandikan nilai sebelum menyimpannya di cookie. Jika Anda melakukan ini, Anda juga harus menggunakan yang sesuaiunescape() berfungsi saat Anda membaca nilai cookie.

Contoh

<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>

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

Sekarang mesin Anda memiliki cookie yang disebut nama. Anda dapat menyetel beberapa cookie menggunakan beberapa pasangan kunci = nilai yang dipisahkan dengan koma.

Membaca Cookies

Membaca cookie sama mudahnya dengan menulis, karena nilai file document.cookieobjek adalah cookie. Jadi, Anda dapat menggunakan string ini kapan pun Anda ingin mengakses cookie. Itudocument.cookie string akan menyimpan daftar pasangan nama = nilai yang dipisahkan oleh titik koma, di mana nama adalah nama cookie dan nilainya adalah nilai stringnya.

Anda dapat menggunakan string ' split() berfungsi untuk memecah string menjadi kunci dan nilai seperti yang ditunjukkan pada contoh berikut.

Contoh

<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 - Di sini, panjang adalah metode kelas Array yang mengembalikan panjang array.

Mungkin ada beberapa cookie lain yang telah disetel di mesin Anda. Kode di atas akan menampilkan semua cookie yang disetel di mesin Anda.

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

Mengatur Tanggal Kedaluwarsa Cookies

Anda dapat memperpanjang umur cookie di luar sesi browser saat ini dengan mengatur tanggal kedaluwarsa dan menyimpan tanggal kedaluwarsa di dalam cookie. Ini dapat dilakukan dengan menyetel atribut 'expires' [kedaluwarsa] ke tanggal dan waktu. Contoh berikut mengilustrasikan cara memperpanjang tanggal kedaluwarsa cookie 1 bulan.

Contoh

<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>

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

Menghapus Cookie

Terkadang Anda ingin menghapus cookie sehingga upaya membaca cookie berikutnya tidak menghasilkan apa-apa. Untuk melakukan ini, Anda hanya perlu mengatur tanggal kedaluwarsa ke waktu di masa lalu. Contoh berikut menggambarkan cara menghapus cookie dengan menyetel tanggal kedaluwarsa menjadi satu bulan di belakang tanggal saat ini.

Contoh

<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>

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.