ES6 - कुकीज़

वेब ब्राउजर और सर्वर संचार के लिए HTTP प्रोटोकॉल का उपयोग करते हैं। HTTP स्टेटलेस प्रोटोकॉल है, अर्थात, यह क्लाइंट द्वारा किए गए कई अनुरोधों पर ग्राहक के डेटा को बनाए नहीं रखता है। क्लाइंट और सर्वर के बीच यह पूर्ण अनुरोध-प्रतिक्रिया चक्र ए के रूप में परिभाषित किया गया हैsession। उपयोगकर्ता के सत्र से संबंधित डेटा को संग्रहीत करने के लिए कुकीज़ ब्राउज़र द्वारा उपयोग किया जाने वाला डिफ़ॉल्ट तंत्र है।

यह काम किस प्रकार करता है?

आपका सर्वर कुकी के रूप में विज़िटर के ब्राउज़र में कुछ डेटा भेजता है। ब्राउज़र कुकी को स्वीकार कर सकता है। यदि ऐसा होता है, तो इसे विज़िटर की हार्ड ड्राइव पर एक सादे टेक्स्ट रिकॉर्ड के रूप में संग्रहीत किया जाता है। अब, जब आगंतुक आपकी साइट पर किसी अन्य पेज पर आता है, तो ब्राउज़र उसी कुकी को रिट्रीवल के लिए सर्वर पर भेजता है। एक बार पुनर्प्राप्त होने के बाद, आपका सर्वर जानता है / याद रखता है कि पहले क्या संग्रहीत किया गया था।

कुकीज़ 5 चर-लंबाई क्षेत्रों के सादे पाठ डेटा रिकॉर्ड हैं।

  • Expires- कुकी की तारीख समाप्त हो जाएगी। यदि यह रिक्त है, तो आगंतुक के ब्राउज़र को छोड़ने पर कुकी समाप्त हो जाएगी।

  • Domain - आपकी साइट का डोमेन नाम।

  • Path- निर्देशिका या वेब पेज के लिए पथ जो कुकी सेट करता है। यह रिक्त हो सकता है, यदि आप कुकी को किसी भी निर्देशिका या पृष्ठ से पुनर्प्राप्त करना चाहते हैं।

  • Secure- यदि इस फ़ील्ड में "सुरक्षित" शब्द है, तो कुकी को केवल एक सुरक्षित सर्वर के साथ पुनर्प्राप्त किया जा सकता है। यदि यह फ़ील्ड रिक्त है, तो ऐसा कोई प्रतिबंध मौजूद नहीं है।

  • Name = Value - कुकीज़ कुंजी-मूल्य जोड़े के रूप में सेट और पुनर्प्राप्त की जाती हैं।

कुकीज़ मूल रूप से CGI प्रोग्रामिंग के लिए डिज़ाइन की गई थीं। कुकी में मौजूद डेटा स्वचालित रूप से वेब ब्राउज़र और वेब सर्वर के बीच संचारित होता है, इसलिए सर्वर पर CGI स्क्रिप्ट कुकी मानों को पढ़ और लिख सकता है जो क्लाइंट साइड पर संग्रहीत होते हैं।

दस्तावेज़ दस्तावेज़ की कुकी संपत्ति का उपयोग करके जावास्क्रिप्ट भी कुकीज़ में हेरफेर कर सकती है। जावास्क्रिप्ट वर्तमान वेब पेज पर लागू होने वाली कुकीज़ को पढ़, बना, संशोधित और हटा सकता है।

स्टोरिंग कुकीज़

कुकी बनाने का सबसे सरल तरीका है, स्ट्रिंग मान निर्दिष्ट करना document.cookie ऑब्जेक्ट, जो इस तरह दिखता है।

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

यहाँ, 'एक्सपायर' विशेषता वैकल्पिक है। यदि आप एक मान्य दिनांक या समय के साथ यह विशेषता प्रदान करते हैं, तो कुकी दी गई तिथि या समय पर समाप्त हो जाएगी और उसके बाद, कुकीज़ का मूल्य सुलभ नहीं होगा।

Note- कुकी मानों में अर्धविराम, अल्पविराम या व्हॉट्सएप शामिल नहीं हो सकते हैं। इस कारण से, आप जावास्क्रिप्ट का उपयोग करना चाह सकते हैंescape()कुकी में संग्रहीत करने से पहले मान को एन्कोड करने के लिए फ़ंक्शन। यदि आप ऐसा करते हैं, तो आपको संबंधित का भी उपयोग करना होगाunescape() जब आप कुकी मान पढ़ते हैं तो कार्य करते हैं।

उदाहरण

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

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

अब आपकी मशीन में एक कुकी नाम है। आप कॉमा द्वारा अलग किए गए कई कुंजी = मान जोड़े का उपयोग करके कई कुकीज़ सेट कर सकते हैं।

कुकीज़ पढ़ना

कुकी को पढ़ना उतना ही सरल है, जितना कि लिखना document.cookieवस्तु कुकी है। इसलिए जब भी आप कुकी एक्सेस करना चाहते हैं, तो आप इस स्ट्रिंग का उपयोग कर सकते हैं। document.cookie स्ट्रिंग नाम की एक सूची रखेगा = मूल्य जोड़े अर्धविरामों द्वारा अलग किए जाएंगे, जहां नाम कुकी का नाम है और मूल्य इसका स्ट्रिंग मान है।

आप तार का उपयोग कर सकते हैं ' split() निम्न उदाहरण में दिखाए गए अनुसार स्ट्रिंग को कुंजी और मानों में तोड़ने के लिए।

उदाहरण

<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 - यहाँ, लंबाई ऐरे वर्ग की एक विधि है जो एक सरणी की लंबाई लौटाती है।

आपकी मशीन पर पहले से ही कुछ अन्य कुकीज हो सकती हैं। उपरोक्त कोड आपके मशीन पर सेट सभी कुकीज़ को प्रदर्शित करेगा।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

कुकीज़ समाप्ति तिथि निर्धारित करना

आप समाप्ति तिथि सेट करके और कुकी के भीतर की समाप्ति की तारीख को सहेजकर वर्तमान ब्राउज़र सत्र से परे कुकी के जीवन का विस्तार कर सकते हैं। यह एक तिथि और समय के लिए 'समय सीमा समाप्त' विशेषता सेट करके किया जा सकता है। निम्न उदाहरण दिखाता है कि कुकी की समाप्ति तिथि को 1 महीने तक कैसे बढ़ाया जाए।

उदाहरण

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

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

एक कुकी को हटाना

कभी-कभी आप एक कुकी को हटाना चाहेंगे, ताकि बाद में कुकी वापस पढ़ने के प्रयास से कुछ भी न हो। ऐसा करने के लिए, आपको बस एक समय में समाप्ति की तारीख निर्धारित करने की आवश्यकता है। निम्न उदाहरण दिखाता है कि वर्तमान तिथि से एक महीने पहले इसकी समाप्ति तिथि निर्धारित करके कुकी को कैसे हटाया जाए।

उदाहरण

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

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।