सर्वलेट्स - कुकीज़ हैंडलिंग
कुकीज़ पाठ फ़ाइलें क्लाइंट कंप्यूटर पर संग्रहीत होती हैं और उन्हें विभिन्न सूचना ट्रैकिंग उद्देश्य के लिए रखा जाता है। जावा सर्वलेट्स HTTP कुकीज़ का पारदर्शी समर्थन करता है।
लौटे उपयोगकर्ताओं की पहचान करने में तीन चरण शामिल हैं -
सर्वर स्क्रिप्ट ब्राउज़र में कुकीज़ का एक सेट भेजता है। उदाहरण के लिए नाम, उम्र, या पहचान संख्या आदि।
ब्राउज़र भविष्य की उपयोग के लिए स्थानीय मशीन पर इस जानकारी को संग्रहीत करता है।
जब अगली बार ब्राउज़र वेब सर्वर को कोई अनुरोध भेजता है तो यह उन कुकीज़ की जानकारी सर्वर को भेजता है और सर्वर उस जानकारी का उपयोग उपयोगकर्ता की पहचान करने के लिए करता है।
यह अध्याय आपको सिखाएगा कि कुकीज़ को कैसे सेट या रीसेट करना है, कैसे उन्हें एक्सेस करना है और कैसे डिलीट करना है।
एक कुकी की शारीरिक रचना
कुकीज़ आमतौर पर एक HTTP हेडर में सेट की जाती हैं (हालांकि जावास्क्रिप्ट एक ब्राउज़र पर सीधे कुकी भी सेट कर सकती है)। एक कुकी सेट करने वाला सर्वलेट हेडर भेज सकता है जो कुछ इस तरह दिखता है -
HTTP/1.1 200 OK
Date: Fri, 04 Feb 2000 21:03:38 GMT
Server: Apache/1.3.9 (UNIX) PHP/4.0b3
Set-Cookie: name = xyz; expires = Friday, 04-Feb-07 22:03:38 GMT;
path = /; domain = tutorialspoint.com
Connection: close
Content-Type: text/html
जैसा कि आप देख सकते हैं, सेट-कुकी हेडर में एक नाम मान युग्म, एक जीएमटी तिथि, एक पथ और एक डोमेन होता है। नाम और मान URL एनकोडेड होगा। एक्सपायर फील्ड ब्राउज़र को एक निर्देश है कि दिए गए समय और तारीख के बाद कुकी को "भूल" करें।
यदि ब्राउज़र कुकीज़ को संग्रहीत करने के लिए कॉन्फ़िगर किया गया है, तो यह समाप्ति तिथि तक यह जानकारी रखेगा। यदि उपयोगकर्ता कुकी के पथ और डोमेन से मेल खाने वाले किसी भी पृष्ठ पर ब्राउज़र को इंगित करता है, तो यह कुकी को सर्वर पर भेज देगा। ब्राउज़र के हेडर कुछ इस तरह दिख सकते हैं -
GET / HTTP/1.0
Connection: Keep-Alive
User-Agent: Mozilla/4.6 (X11; I; Linux 2.2.6-15apmac ppc)
Host: zink.demon.co.uk:1126
Accept: image/gif, */*
Accept-Encoding: gzip
Accept-Language: en
Accept-Charset: iso-8859-1,*,utf-8
Cookie: name = xyz
एक सर्वलेट तब अनुरोध विधि request.getCookies () के माध्यम से कुकी तक पहुंच होगी, जो कुकी ऑब्जेक्ट की एक सरणी देता है ।
सर्वलेट कुकीज़ विधियाँ
निम्नलिखित उपयोगी तरीकों की सूची है जो आप सर्वलेट में कुकीज़ में हेरफेर करते समय उपयोग कर सकते हैं।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | public void setDomain(String pattern) यह विधि उस डोमेन को सेट करती है जिस पर कुकी लागू होती है, उदाहरण के लिए tutorialspoint.com। |
2 | public String getDomain() इस विधि को वह डोमेन मिलता है जिस पर कुकी लागू होती है, उदाहरण के लिए tutorialspoint.com। |
3 | public void setMaxAge(int expiry) यह विधि कुकी को समाप्त होने से पहले कितना समय (सेकंड में) सेट करना चाहिए। यदि आप इसे सेट नहीं करते हैं, तो कुकी केवल वर्तमान सत्र के लिए चलेगी। |
4 | public int getMaxAge() यह विधि कुकी की अधिकतम आयु लौटाती है, सेकंड में निर्दिष्ट, डिफ़ॉल्ट रूप से, -1 यह दर्शाता है कि कुकी बंद होने तक बनी रहेगी। |
5 | public String getName() यह विधि कुकी का नाम देती है। निर्माण के बाद नाम नहीं बदला जा सकता है। |
6 | public void setValue(String newValue) यह विधि कुकी से संबंधित मान सेट करती है |
7 | public String getValue() इस विधि से कुकी से जुड़ा मूल्य प्राप्त होता है। |
8 | public void setPath(String uri) यह विधि उस पथ को सेट करती है जिस पर यह कुकी लागू होती है। यदि आप कोई पथ निर्दिष्ट नहीं करते हैं, तो कुकी को सभी URL के लिए एक ही निर्देशिका में वर्तमान पृष्ठ के साथ-साथ सभी उपनिर्देशिकाओं के लिए लौटा दिया जाता है। |
9 | public String getPath() इस विधि को वह रास्ता मिलता है जिस पर यह कुकी लागू होती है। |
10 | public void setSecure(boolean flag) यह विधि बूलियन मान को इंगित करती है कि क्या कुकी को केवल एन्क्रिप्टेड (यानी एसएसएल) कनेक्शन पर भेजा जाना चाहिए। |
1 1 | public void setComment(String purpose) यह विधि एक टिप्पणी निर्दिष्ट करती है जो कुकी के उद्देश्य का वर्णन करती है। यदि ब्राउज़र उपयोगकर्ता के लिए कुकी प्रस्तुत करता है तो यह टिप्पणी उपयोगी है। |
12 | public String getComment() यह विधि इस कुकी के उद्देश्य का वर्णन करते हुए टिप्पणी लौटाती है, या यदि कुकी की कोई टिप्पणी नहीं है, तो इसे रद्द कर दें। |
सर्वलेट के साथ कुकीज़ सेट करना
सर्वलेट के साथ कुकीज़ सेट करना तीन चरणों में शामिल है -
(1) Creating a Cookie object - आप कुकी निर्माता को कुकी नाम और कुकी मान के साथ कहते हैं, दोनों तार हैं।
Cookie cookie = new Cookie("key","value");
ध्यान रखें, न तो नाम और न ही मूल्य में सफेद स्थान या निम्न में से कोई भी वर्ण होना चाहिए -
[ ] ( ) = , " / ? @ : ;
(2) Setting the maximum age- आप कुकी को वैध होने के लिए कितनी देर (सेकंड में) यह निर्दिष्ट करने के लिए सेटमैक्सएज का उपयोग करते हैं। इसके बाद 24 घंटे के लिए एक कुकी स्थापित की जाएगी।
cookie.setMaxAge(60 * 60 * 24);
(3) Sending the Cookie into the HTTP response headers - आप HTTP प्रतिक्रिया हेडर में कुकीज़ जोड़ने के लिए response.addCookie का उपयोग इस प्रकार करते हैं -
response.addCookie(cookie);
उदाहरण
आइए पहले और अंतिम नाम के लिए कुकीज़ सेट करने के लिए अपने फॉर्म उदाहरण को संशोधित करें।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class HelloForm extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Create cookies for first and last names.
Cookie firstName = new Cookie("first_name", request.getParameter("first_name"));
Cookie lastName = new Cookie("last_name", request.getParameter("last_name"));
// Set expiry date after 24 Hrs for both the cookies.
firstName.setMaxAge(60*60*24);
lastName.setMaxAge(60*60*24);
// Add both the cookies in the response header.
response.addCookie( firstName );
response.addCookie( lastName );
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Setting Cookies Example";
String docType =
"<!doctype html public \"-//w3c//dtd html 4.0 " + "transitional//en\">\n";
out.println(docType +
"<html>\n" +
"<head>
<title>" + title + "</title>
</head>\n" +
"<body bgcolor = \"#f0f0f0\">\n" +
"<h1 align = \"center\">" + title + "</h1>\n" +
"<ul>\n" +
" <li><b>First Name</b>: "
+ request.getParameter("first_name") + "\n" +
" <li><b>Last Name</b>: "
+ request.getParameter("last_name") + "\n" +
"</ul>\n" +
"</body>
</html>"
);
}
}
उपरोक्त सर्वलेट संकलित करें HelloForm और web.xml फ़ाइल में उचित प्रविष्टि बनाएं और अंत में सर्वलेट कॉल करने के लिए HTML पेज का अनुसरण करें।
<html>
<body>
<form action = "HelloForm" method = "GET">
First Name: <input type = "text" name = "first_name">
<br />
Last Name: <input type = "text" name = "last_name" />
<input type = "submit" value = "Submit" />
</form>
</body>
</html>
एक फ़ाइल Hello.htm में HTML सामग्री के ऊपर रखें और इसे <Tomcat-installationdirectory> / webapps / ROOT निर्देशिका में डालें। जब आप http: // localhost: 8080 / Hello.htm को एक्सेस करेंगे , तो यहां उपरोक्त फॉर्म का वास्तविक आउटपुट है।
पहले नाम और अंतिम नाम दर्ज करने का प्रयास करें और फिर सबमिट बटन पर क्लिक करें। यह आपकी स्क्रीन पर पहला नाम और अंतिम नाम प्रदर्शित करेगा और उसी समय यह दो कुकीज़ को सेट करेगा पहला नाम और अंतिम नाम जो सर्वर पर वापस भेजा जाएगा जब अगली बार आप सबमिट बटन दबाएंगे।
अगला भाग आपको समझाएगा कि आप अपने वेब एप्लिकेशन में इन कुकीज़ को कैसे एक्सेस करेंगे।
सर्वलेट के साथ कुकीज़ पढ़ना
कुकीज़ पढ़ने के लिए, आपको कॉल करके javax.servlet.http.Cookie ऑब्जेक्ट्स की एक सरणी बनाने की आवश्यकता हैgetCookies()HttpServletRequest की विधि । फिर सरणी के माध्यम से चक्र करें, और प्रत्येक कुकी और संबद्ध मान तक पहुंचने के लिए getName () और getValue () विधियों का उपयोग करें।
उदाहरण
आइए हम कुकीज़ पढ़ते हैं जिसे हमने पिछले उदाहरण में सेट किया है -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class ReadCookies extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
Cookie cookie = null;
Cookie[] cookies = null;
// Get an array of Cookies associated with this domain
cookies = request.getCookies();
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Reading Cookies Example";
String docType =
"<!doctype html public \"-//w3c//dtd html 4.0 " +
"transitional//en\">\n";
out.println(docType +
"<html>\n" +
"<head><title>" + title + "</title></head>\n" +
"<body bgcolor = \"#f0f0f0\">\n" );
if( cookies != null ) {
out.println("<h2> Found Cookies Name and Value</h2>");
for (int i = 0; i < cookies.length; i++) {
cookie = cookies[i];
out.print("Name : " + cookie.getName( ) + ", ");
out.print("Value: " + cookie.getValue( ) + " <br/>");
}
} else {
out.println("<h2>No cookies founds</h2>");
}
out.println("</body>");
out.println("</html>");
}
}
सर्वलेट के ऊपर संकलन करें ReadCookiesऔर web.xml फ़ाइल में उचित प्रविष्टि बनाएँ। यदि आपने "जॉन" के रूप में First_name कुकी और "खिलाड़ी" के रूप में last_name कुकी सेट की है, तो http: // localhost: 8080 / ReadCookies निम्न परिणाम प्रदर्शित करेगा -
Found Cookies Name and Value
Name : first_name, Value: John
Name : last_name, Value: Player
सर्वलेट के साथ कुकीज़ हटाएं
कुकीज़ हटाने के लिए बहुत सरल है। यदि आप एक कुकी को हटाना चाहते हैं तो आपको बस तीन चरणों का पालन करना होगा -
पहले से मौजूद कुकी को पढ़ें और कुकी ऑब्जेक्ट में स्टोर करें।
कुकी आयु को शून्य का उपयोग करके सेट करें setMaxAge() मौजूदा कुकी को हटाने की विधि
प्रतिक्रिया शीर्षलेख में इस कुकी को वापस जोड़ें।
उदाहरण
निम्न उदाहरण "first_name" नामक कुकी को हटा देगा और मौजूदा कर देगा और जब आप अगली बार ReadCookies सर्वलेट चलाएंगे, तो यह first_name के लिए शून्य मान लौटाएगा।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class DeleteCookies extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
Cookie cookie = null;
Cookie[] cookies = null;
// Get an array of Cookies associated with this domain
cookies = request.getCookies();
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Delete Cookies Example";
String docType =
"<!doctype html public \"-//w3c//dtd html 4.0 " + "transitional//en\">\n";
out.println(docType +
"<html>\n" +
"<head><title>" + title + "</title></head>\n" +
"<body bgcolor = \"#f0f0f0\">\n" );
if( cookies != null ) {
out.println("<h2> Cookies Name and Value</h2>");
for (int i = 0; i < cookies.length; i++) {
cookie = cookies[i];
if((cookie.getName( )).compareTo("first_name") == 0 ) {
cookie.setMaxAge(0);
response.addCookie(cookie);
out.print("Deleted cookie : " + cookie.getName( ) + "<br/>");
}
out.print("Name : " + cookie.getName( ) + ", ");
out.print("Value: " + cookie.getValue( )+" <br/>");
}
} else {
out.println("<h2>No cookies founds</h2>");
}
out.println("</body>");
out.println("</html>");
}
}
सर्वलेट के ऊपर संकलन करें DeleteCookiesऔर web.xml फ़ाइल में उचित प्रविष्टि बनाएँ। अब http: // localhost चल रहा है : 8080 / DeleteCookies निम्नलिखित परिणाम प्रदर्शित करेगा -
Cookies Name and Value
Deleted cookie : first_name
Name : first_name, Value: John
Name : last_name, Value: Player
अब http: // localhost: 8080 / ReadCookies चलाने की कोशिश करें और यह केवल एक कुकी को इस प्रकार प्रदर्शित करेगा -
Found Cookies Name and Value
Name : last_name, Value: Player
आप अपने कुकीज़ को इंटरनेट एक्सप्लोरर में मैन्युअल रूप से हटा सकते हैं। टूल मेनू पर प्रारंभ करें और इंटरनेट विकल्प चुनें। सभी कुकी हटाने के लिए, कुकीज़ हटाएं दबाएं।