JavaScript dan Cookie

Apa itu Cookies?

Browser dan Server Web menggunakan protokol HTTP untuk berkomunikasi dan HTTP adalah protokol tanpa negara. Tetapi untuk situs web komersial, diperlukan untuk menjaga informasi sesi di antara halaman yang berbeda. Misalnya, satu pendaftaran pengguna berakhir setelah menyelesaikan banyak halaman. Tetapi bagaimana menjaga informasi sesi pengguna di semua halaman web.

Dalam banyak situasi, menggunakan cookie adalah metode paling efisien untuk mengingat dan melacak preferensi, pembelian, komisi, dan informasi lain yang diperlukan untuk pengalaman pengunjung atau statistik situs yang lebih baik.

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 catatan 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 klien.

JavaScript juga dapat memanipulasi cookie menggunakan cookie milik dari Documentobyek. 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 objek document.cookie, yang terlihat seperti ini.

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

Di sini expiresatribut adalah opsional. Jika Anda memberikan atribut ini dengan tanggal atau waktu yang valid, maka 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

Coba berikut ini. Ini menetapkan nama pelanggan dalam cookie masukan.

<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 Cookie" onclick = "WriteCookie();"/>
      </form>   
   </body>
</html>

Keluaran

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

Membaca Cookies

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

Anda dapat menggunakan string ' split() berfungsi untuk memecah string menjadi kunci dan nilai sebagai berikut -

Contoh

Coba contoh berikut untuk mendapatkan semua cookie.

<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 - Sini length adalah metode Arraykelas yang mengembalikan panjang array. Kami akan membahas Array di bab terpisah. Pada saat itu, cobalah untuk mencernanya.

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

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 mengatur‘expires’ atribut ke tanggal dan waktu.

Contoh

Coba contoh berikut. Ini menggambarkan bagaimana memperpanjang tanggal kedaluwarsa cookie selama 1 Bulan.

<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 = "myform" action = "">
         Enter name: <input type = "text" name = "customer"/>
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/>
      </form>      
   </body>
</html>

Keluaran

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

Coba contoh berikut. Ini menggambarkan bagaimana menghapus cookie dengan mengatur tanggal kedaluwarsa menjadi satu bulan di belakang tanggal saat ini.

<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 = "myform" action = "">
         Enter name: <input type = "text" name = "customer"/>
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/>
      </form>      
   </body>
</html>

Keluaran