जावास्क्रिप्ट और कुकीज़
कुकीज़ क्या हैं?
वेब ब्राउजर और सर्वर संचार के लिए HTTP प्रोटोकॉल का उपयोग करते हैं और HTTP एक स्टेटलेस प्रोटोकॉल है। लेकिन एक वाणिज्यिक वेबसाइट के लिए, विभिन्न पृष्ठों के बीच सत्र की जानकारी बनाए रखना आवश्यक है। उदाहरण के लिए, एक उपयोगकर्ता पंजीकरण कई पृष्ठों को पूरा करने के बाद समाप्त होता है। लेकिन सभी वेब पृष्ठों पर उपयोगकर्ताओं की सत्र जानकारी कैसे बनाए रखें।
कई स्थितियों में, कुकीज़ का उपयोग करना याद रखने और वरीयताओं के अनुभव, या साइट के आँकड़ों के लिए आवश्यक वरीयताओं, खरीद, कमीशन और अन्य जानकारी को ट्रैक करने का सबसे कुशल तरीका है।
यह काम किस प्रकार करता है ?
आपका सर्वर कुकी के रूप में विज़िटर के ब्राउज़र में कुछ डेटा भेजता है। ब्राउज़र कुकी को स्वीकार कर सकता है। यदि ऐसा होता है, तो इसे विज़िटर की हार्ड ड्राइव पर एक सादे टेक्स्ट रिकॉर्ड के रूप में संग्रहीत किया जाता है। अब, जब आगंतुक आपकी साइट पर किसी अन्य पेज पर आता है, तो ब्राउज़र उसी कुकी को रिट्रीवल के लिए सर्वर पर भेजता है। एक बार पुनर्प्राप्त होने के बाद, आपका सर्वर जानता है / याद रखता है कि पहले क्या संग्रहीत किया गया था।
कुकीज़ 5 चर-लंबाई वाले फ़ील्ड का एक सादा पाठ डेटा रिकॉर्ड हैं -
Expires- कुकी की तारीख समाप्त हो जाएगी। यदि यह रिक्त है, तो विज़िटर द्वारा ब्राउज़र को छोड़ने पर कुकी समाप्त हो जाएगी।
Domain - आपकी साइट का डोमेन नाम।
Path- कुकी को सेट करने वाली निर्देशिका या वेब पेज का पथ। यदि आप किसी भी निर्देशिका या पृष्ठ से कुकी को पुनः प्राप्त करना चाहते हैं तो यह रिक्त हो सकता है।
Secure- यदि इस फ़ील्ड में "सुरक्षित" शब्द है, तो कुकी को केवल एक सुरक्षित सर्वर के साथ पुनर्प्राप्त किया जा सकता है। यदि यह फ़ील्ड रिक्त है, तो ऐसा कोई प्रतिबंध मौजूद नहीं है।
Name=Value - कुकीज़ कुंजी-मूल्य जोड़े के रूप में सेट और पुनर्प्राप्त की जाती हैं
कुकीज़ मूल रूप से CGI प्रोग्रामिंग के लिए डिज़ाइन की गई थीं। कुकी में निहित डेटा स्वचालित रूप से वेब ब्राउज़र और वेब सर्वर के बीच संचारित होता है, इसलिए सर्वर पर CGI स्क्रिप्ट कुकी मानों को पढ़ और लिख सकता है जो क्लाइंट पर संग्रहीत होते हैं।
जावास्क्रिप्ट भी कुकीज़ का उपयोग कर हेरफेर कर सकते हैं cookie की संपत्ति Documentवस्तु। जावास्क्रिप्ट वर्तमान वेब पेज पर लागू होने वाली कुकीज़ को पढ़, बना, संशोधित और हटा सकता है।
स्टोरिंग कुकीज़
कुकी बनाने का सबसे सरल तरीका डॉक्युमेंट.कॉकी ऑब्जेक्ट को एक स्ट्रिंग मान असाइन करना है, जो इस तरह दिखता है।
document.cookie = "key1 = value1;key2 = value2;expires = date";
यहां ही expiresविशेषता वैकल्पिक है। यदि आप एक मान्य दिनांक या समय के साथ इस विशेषता को प्रदान करते हैं, तो कुकी किसी निश्चित तिथि या समय पर समाप्त हो जाएगी और उसके बाद, कुकीज़ का मूल्य सुलभ नहीं होगा।
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 Cookie" onclick = "WriteCookie();"/>
</form>
</body>
</html>
उत्पादन
अब आपकी मशीन में कुकी नाम की मशीन है name। आप कॉमा द्वारा अलग किए गए कई कुंजी = मान जोड़े का उपयोग करके कई कुकीज़ सेट कर सकते हैं।
कुकीज़ पढ़ना
कुकी पढ़ना केवल एक लिखने के रूप में सरल है, क्योंकि दस्तावेज़ का मूल्य। कुकी ऑब्जेक्ट कुकी है। इसलिए जब भी आप कुकी एक्सेस करना चाहते हैं, तो आप इस स्ट्रिंग का उपयोग कर सकते हैं। Document.cookie string, semicolons द्वारा अलग किए गए नाम = मान जोड़े की एक सूची रखेगाname कुकी का नाम है और मान इसका स्ट्रिंग मान है।
आप तार का उपयोग कर सकते हैं ' 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 - यहाँ length की एक विधि है Arrayवह वर्ग जो किसी सरणी की लंबाई लौटाता है। हम एक अलग अध्याय में एरेस पर चर्चा करेंगे। तब तक, कृपया इसे पचाने का प्रयास करें।
Note- हो सकता है कि आपकी मशीन पर पहले से ही कुछ अन्य कुकीज हों। उपरोक्त कोड आपके मशीन पर सेट सभी कुकीज़ को प्रदर्शित करेगा।
कुकीज़ समाप्ति तिथि निर्धारित करना
आप समाप्ति तिथि सेट करके और कुकी के भीतर की समाप्ति तिथि को सहेजकर वर्तमान ब्राउज़र सत्र से परे कुकी के जीवन का विस्तार कर सकते हैं। यह सेटिंग करके किया जा सकता है‘expires’ एक तिथि और समय के लिए विशेषता।
उदाहरण
निम्न उदाहरण का प्रयास करें। यह दिखाता है कि कुकी की समाप्ति तिथि को 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 = "myform" action = "">
Enter 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 = "myform" action = "">
Enter name: <input type = "text" name = "customer"/>
<input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/>
</form>
</body>
</html>