सर्वलेट्स - सत्र ट्रैकिंग
HTTP एक "स्टेटलेस" प्रोटोकॉल है जिसका अर्थ है कि हर बार जब ग्राहक वेब पेज को पुनः प्राप्त करता है, तो क्लाइंट वेब सर्वर से एक अलग कनेक्शन खोलता है और सर्वर स्वचालित रूप से पिछले क्लाइंट अनुरोध का कोई रिकॉर्ड नहीं रखता है।
अभी भी वेब क्लाइंट और वेब सर्वर के बीच सत्र बनाए रखने के तीन तरीके हैं -
कुकीज़
एक वेबसर्वर प्रत्येक वेब क्लाइंट के लिए कुकी के रूप में एक अद्वितीय सत्र आईडी असाइन कर सकता है और क्लाइंट से बाद के अनुरोधों के लिए उन्हें प्राप्त कुकी का उपयोग करके पहचाना जा सकता है।
यह एक प्रभावी तरीका नहीं हो सकता है क्योंकि कई बार ब्राउज़र एक कुकी का समर्थन नहीं करता है, इसलिए मैं सत्र को बनाए रखने के लिए इस प्रक्रिया का उपयोग करने की अनुशंसा नहीं करूंगा।
हिडन फॉर्म फील्ड्स
एक वेब सर्वर एक अनोखा सेशन आईडी के साथ एक हिडन HTML फॉर्म फील्ड भेज सकता है -
<input type = "hidden" name = "sessionid" value = "12345">
इस प्रविष्टि का मतलब है कि, जब फॉर्म जमा किया जाता है, तो निर्दिष्ट नाम और मूल्य स्वचालित रूप से GET या POST डेटा में शामिल होते हैं। हर बार जब वेब ब्राउज़र अनुरोध वापस भेजता है, तो अलग-अलग वेब ब्राउज़र का ट्रैक रखने के लिए session_id मान का उपयोग किया जा सकता है।
यह सत्र का ट्रैक रखने का एक प्रभावी तरीका हो सकता है लेकिन नियमित (<HREF...>) हाइपरटेक्स्ट लिंक पर क्लिक करने से फ़ॉर्म सबमिट नहीं होता है, इसलिए छिपे हुए फ़ॉर्म फ़ील्ड भी सामान्य सत्र ट्रैकिंग का समर्थन नहीं कर सकते हैं।
URL रीराइटिंग
आप प्रत्येक URL के अंत में कुछ अतिरिक्त डेटा जोड़ सकते हैं जो सत्र की पहचान करता है, और सर्वर उस सत्र पहचानकर्ता को उस सत्र के साथ संग्रहीत डेटा के साथ जोड़ सकता है।
उदाहरण के लिए, http://tutorialspoint.com/file.htm=sessionid = 12345 के साथ, सत्र पहचानकर्ता सत्रांक = 12345 के रूप में संलग्न है जिसे क्लाइंट की पहचान करने के लिए वेब सर्वर पर एक्सेस किया जा सकता है।
URL पुनर्लेखन सत्रों को बनाए रखने का एक बेहतर तरीका है और यह तब भी काम करता है जब ब्राउज़र कुकीज़ का समर्थन नहीं करते हैं। URL री-राइटिंग का दोष यह है कि आपको एक साधारण स्टेटिक HTML पेज की स्थिति में भी, सत्र ID को असाइन करने के लिए हर URL को गतिशील रूप से जनरेट करना होगा।
HttpSession ऑब्जेक्ट
उपर्युक्त तीन तरीकों के अलावा, सर्वलेट HttpSession Interface प्रदान करता है जो एक उपयोगकर्ता को एक से अधिक पृष्ठ अनुरोधों की पहचान करने या किसी वेब साइट पर जाने और उस उपयोगकर्ता के बारे में जानकारी संग्रहीत करने का एक तरीका प्रदान करता है।
सर्वलेट कंटेनर एक HTTP क्लाइंट और एक HTTP सर्वर के बीच एक सत्र बनाने के लिए इस इंटरफ़ेस का उपयोग करता है। सत्र उपयोगकर्ता से एक से अधिक कनेक्शन या पृष्ठ अनुरोध पर एक निर्दिष्ट समयावधि के लिए बना रहता है।
आप सार्वजनिक विधि को कॉल करके HttpSession ऑब्जेक्ट प्राप्त करेंगे getSession() HttpServletRequest के रूप में, नीचे -
HttpSession session = request.getSession();
क्लाइंट को कोई भी दस्तावेज़ सामग्री भेजने से पहले आपको request.getSession () कॉल करना होगा। यहाँ HttpSession ऑब्जेक्ट के माध्यम से उपलब्ध महत्वपूर्ण विधियों का सारांश दिया गया है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | public Object getAttribute(String name) यह विधि इस सत्र में निर्दिष्ट नाम के साथ बंधी हुई वस्तु को लौटा देती है, या नाम के तहत कोई वस्तु नहीं बंधने पर अशक्त हो जाती है। |
2 | public Enumeration getAttributeNames() इस पद्धति में इस सत्र से जुड़ी सभी वस्तुओं के नाम वाली स्ट्रिंग ऑब्जेक्ट्स की गणना होती है। |
3 | public long getCreationTime() यह विधि उस समय को लौटाती है जब इस सत्र को बनाया गया था, 1 जनवरी, 1970 जीएमटी के बाद से मिलीसेकंड में मापा गया था। |
4 | public String getId() यह विधि इस सत्र में निर्दिष्ट विशिष्ट पहचानकर्ता युक्त स्ट्रिंग लौटाती है। |
5 | public long getLastAccessedTime() यह विधि सत्र के अंतिम समय तक पहुँच जाती है, 1 जनवरी 1970 GMT की आधी रात से मिलीसेकंड के प्रारूप में |
6 | public int getMaxInactiveInterval() यह विधि अधिकतम समय अंतराल (सेकंड) लौटाती है, कि सर्वलेट कंटेनर क्लाइंट एक्सेस के बीच सत्र को खुला रखेगा। |
7 | public void invalidate() यह विधि इस सत्र को अमान्य कर देती है और इससे जुड़ी किसी भी वस्तु को खोल देती है। |
8 | public boolean isNew( यदि ग्राहक को सत्र के बारे में अभी तक जानकारी नहीं है या यदि ग्राहक सत्र में शामिल नहीं होने का विकल्प चुनता है तो यह विधि सही साबित होती है। |
9 | public void removeAttribute(String name) यह विधि इस सत्र से निर्दिष्ट नाम के साथ बंधी हुई वस्तु को हटा देती है। |
10 | public void setAttribute(String name, Object value) यह विधि निर्दिष्ट निर्दिष्ट नाम का उपयोग करते हुए इस सत्र के लिए एक वस्तु को बांधती है। |
1 1 | public void setMaxInactiveInterval(int interval) यह विधि समय को निर्दिष्ट करती है, सेकंड में, ग्राहक अनुरोधों के बीच सर्वलेट कंटेनर से पहले इस सत्र को अमान्य कर देगा। |
सत्र ट्रैकिंग उदाहरण
यह उदाहरण बताता है कि सत्र के लिए निर्माण समय और अंतिम-एक्सेस किए गए समय का पता लगाने के लिए HttpSession ऑब्जेक्ट का उपयोग कैसे करें। यदि हम पहले से मौजूद नहीं हैं तो हम अनुरोध के साथ एक नया सत्र जोड़ेंगे।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class SessionTrack extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Create a session object if it is already not created.
HttpSession session = request.getSession(true);
// Get session creation time.
Date createTime = new Date(session.getCreationTime());
// Get last access time of this web page.
Date lastAccessTime = new Date(session.getLastAccessedTime());
String title = "Welcome Back to my website";
Integer visitCount = new Integer(0);
String visitCountKey = new String("visitCount");
String userIDKey = new String("userID");
String userID = new String("ABCD");
// Check if this is new comer on your web page.
if (session.isNew()) {
title = "Welcome to my website";
session.setAttribute(userIDKey, userID);
} else {
visitCount = (Integer)session.getAttribute(visitCountKey);
visitCount = visitCount + 1;
userID = (String)session.getAttribute(userIDKey);
}
session.setAttribute(visitCountKey, visitCount);
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
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" +
"<h2 align = \"center\">Session Infomation</h2>\n" +
"<table border = \"1\" align = \"center\">\n" +
"<tr bgcolor = \"#949494\">\n" +
" <th>Session info</th><th>value</th>
</tr>\n" +
"<tr>\n" +
" <td>id</td>\n" +
" <td>" + session.getId() + "</td>
</tr>\n" +
"<tr>\n" +
" <td>Creation Time</td>\n" +
" <td>" + createTime + " </td>
</tr>\n" +
"<tr>\n" +
" <td>Time of Last Access</td>\n" +
" <td>" + lastAccessTime + " </td>
</tr>\n" +
"<tr>\n" +
" <td>User ID</td>\n" +
" <td>" + userID + " </td>
</tr>\n" +
"<tr>\n" +
" <td>Number of visits</td>\n" +
" <td>" + visitCount + "</td>
</tr>\n" +
"</table>\n" +
"</body>
</html>"
);
}
}
उपरोक्त सर्वलेट संकलित करें SessionTrackऔर web.xml फ़ाइल में उचित प्रविष्टि बनाएँ। अब http: // localhost: 8080 / SessionTrack चल रहा है, जब आप पहली बार दौड़ेंगे तो निम्नलिखित परिणाम प्रदर्शित होंगे -
Welcome to my website
Session Infomation
Session info
value
id
0AE3EC93FF44E3C525B4351B77ABB2D5
Creation Time
Tue Jun 08 17:26:40 GMT+04:00 2010
Time of Last Access
Tue Jun 08 17:26:40 GMT+04:00 2010
User ID
ABCD
Number of visits
0
अब दूसरी बार उसी सर्वलेट को चलाने का प्रयास करें, यह निम्नलिखित परिणाम प्रदर्शित करेगा।
Welcome Back to my website
Session Infomation
info type
value
id
0AE3EC93FF44E3C525B4351B77ABB2D5
Creation Time
Tue Jun 08 17:26:40 GMT+04:00 2010
Time of Last Access
Tue Jun 08 17:26:40 GMT+04:00 2010
User ID
ABCD
Number of visits
1
सत्र डेटा हटाना
जब आप उपयोगकर्ता के सत्र डेटा के साथ किया जाता है, तो आपके पास कई विकल्प होते हैं -
Remove a particular attribute- आप किसी विशेष कुंजी से जुड़े मूल्य को हटाने के लिए सार्वजनिक शून्य निष्कासन (स्ट्रिंग नाम) विधि कह सकते हैं ।
Delete the whole session- आप पूरे सत्र को छोड़ने के लिए सार्वजनिक शून्य अमान्य () विधि कह सकते हैं ।
Setting Session timeout- आप व्यक्तिगत रूप से सत्र के लिए टाइमआउट सेट करने के लिए सार्वजनिक शून्य सेटमैक्स इनएक्टिव इन्टरवल (इंट अंतराल) विधि कह सकते हैं ।
Log the user out - सर्वर जो सर्वलेट्स 2.4 का समर्थन करते हैं, आप कॉल कर सकते हैं logout क्लाइंट को वेब सर्वर से लॉग इन करने के लिए और सभी उपयोगकर्ताओं से संबंधित सभी सत्रों को अमान्य करने के लिए।
web.xml Configuration - यदि आप ऊपर बताए गए तरीकों के अलावा टॉमकैट का उपयोग कर रहे हैं, तो आप निम्न सत्र को वेब.xml फ़ाइल में निम्न प्रकार से कॉन्फ़िगर कर सकते हैं।
<session-config>
<session-timeout>15</session-timeout>
</session-config>
समयबाह्य मिनट के रूप में व्यक्त किया जाता है, और डिफ़ॉल्ट समयबाह्य को ओवरराइड करता है जो कि टॉमकैट में 30 मिनट है।
एक सर्वलेट में getMaxInactiveInterval () विधि सेकंड में उस सत्र के लिए टाइमआउट अवधि देता है। इसलिए यदि आपका सत्र 15 मिनट के लिए web.xml में कॉन्फ़िगर किया गया है, तो getMaxInactiveInterval () 900 लौटाता है।