सर्वलेट्स - त्वरित गाइड
सर्वलेट्स क्या हैं?
जावा सर्वलेट्स ऐसे प्रोग्राम हैं जो वेब या एप्लिकेशन सर्वर पर चलते हैं और वेब ब्राउजर या अन्य HTTP क्लाइंट और डेटाबेस या HTTP सर्वर पर एप्लिकेशन से आने वाले अनुरोधों के बीच एक मध्य परत के रूप में कार्य करते हैं।
सर्वलेट्स का उपयोग करके, आप वेब पेज रूपों के माध्यम से उपयोगकर्ताओं से इनपुट एकत्र कर सकते हैं, डेटाबेस या किसी अन्य स्रोत से रिकॉर्ड प्रस्तुत कर सकते हैं और गतिशील रूप से वेब पेज बना सकते हैं।
जावा सर्वलेट्स अक्सर उसी उद्देश्य को पूरा करते हैं जैसे कि कॉमन गेटवे इंटरफेस (CGI) का उपयोग करके कार्यान्वित प्रोग्राम। लेकिन सर्वलेट्स सीजीआई की तुलना में कई फायदे प्रदान करते हैं।
प्रदर्शन काफी बेहतर है।
सर्वलेट्स वेब सर्वर के एड्रेस स्पेस के भीतर निष्पादित होते हैं। प्रत्येक क्लाइंट अनुरोध को संभालने के लिए एक अलग प्रक्रिया बनाने के लिए आवश्यक नहीं है।
सर्वलेट्स प्लेटफ़ॉर्म-स्वतंत्र होते हैं क्योंकि वे जावा में लिखे जाते हैं।
सर्वर पर जावा सुरक्षा प्रबंधक सर्वर मशीन पर संसाधनों की सुरक्षा के लिए प्रतिबंधों का एक सेट लागू करता है। इसलिए सर्वलेट्स पर भरोसा किया जाता है।
जावा वर्ग के पुस्तकालयों की पूर्ण कार्यक्षमता एक सर्वलेट के लिए उपलब्ध है। यह सॉकेट्स और आरएमआई तंत्र के माध्यम से एप्लेट्स, डेटाबेस या अन्य सॉफ्टवेयर के साथ संवाद कर सकता है जिसे आपने पहले ही देखा है।
सर्वलेट्स आर्किटेक्चर
निम्न आरेख एक वेब अनुप्रयोग में सर्वलेट्स की स्थिति को दर्शाता है।
सर्वलेट्स टास्क
सर्वलेट्स निम्नलिखित प्रमुख कार्य करते हैं -
क्लाइंट (ब्राउज़र) द्वारा भेजे गए स्पष्ट डेटा को पढ़ें। इसमें वेब पेज पर HTML फॉर्म शामिल है या यह एप्लेट या कस्टम HTTP क्लाइंट प्रोग्राम से भी आ सकता है।
क्लाइंट (ब्राउज़र) द्वारा भेजे गए अंतर्निहित HTTP अनुरोध डेटा पढ़ें। इसमें कुकीज़, मीडिया प्रकार और संपीड़न योजनाएं शामिल हैं जिन्हें ब्राउज़र समझता है, और इसके आगे।
डेटा संसाधित करें और परिणाम उत्पन्न करें। इस प्रक्रिया के लिए डेटाबेस से बात करना, RMI या CORBA कॉल निष्पादित करना, वेब सेवा लागू करना, या सीधे प्रतिक्रिया की गणना करना पड़ सकता है।
ग्राहकों (ब्राउज़रों) को स्पष्ट डेटा (यानी, दस्तावेज़) भेजें। यह दस्तावेज़ विभिन्न स्वरूपों में भेजा जा सकता है, जिसमें पाठ (HTML या XML), बाइनरी (जीआईएफ चित्र), एक्सेल आदि शामिल हैं।
क्लाइंट (ब्राउज़र) को अंतर्निहित HTTP प्रतिक्रिया भेजें। इसमें ब्राउज़र या अन्य क्लाइंट को यह बताना शामिल है कि किस प्रकार का दस्तावेज़ लौटाया जा रहा है (उदाहरण के लिए, HTML), कुकीज और कैशिंग पैरामीटर सेट करना और ऐसे अन्य कार्य।
सर्वलेट्स पैकेज
जावा सर्वलेट्स जावा क्लासेस एक वेब सर्वर द्वारा चलाया जाता है जिसमें एक दुभाषिया होता है जो जावा सर्वलेट विनिर्देशन का समर्थन करता है।
सर्वलेट्स का उपयोग करके बनाया जा सकता है javax.servlet तथा javax.servlet.http पैकेज, जो जावा के उद्यम संस्करण का एक मानक हिस्सा हैं, जावा क्लास लाइब्रेरी का एक विस्तारित संस्करण है जो बड़े पैमाने पर विकास परियोजनाओं का समर्थन करता है।
ये कक्षाएं जावा सर्वलेट और जेएसपी विनिर्देशों को लागू करती हैं। इस ट्यूटोरियल के लेखन के समय, संस्करण जावा सर्वलेट 2.5 और जेएसपी 2.1 हैं।
जावा सर्वलेट्स को किसी अन्य जावा वर्ग की तरह ही बनाया और संकलित किया गया है। जब आप सर्वलेट पैकेज स्थापित करते हैं और उन्हें अपने कंप्यूटर के Classpath में जोड़ते हैं, तो आप JDK के जावा कंपाइलर या किसी अन्य वर्तमान संकलक के साथ सर्वलेट्स संकलित कर सकते हैं।
आगे क्या है?
मैं सर्वलेट्स के साथ शुरू करने के लिए आपके पर्यावरण को स्थापित करने के लिए कदम से कदम उठाऊंगा। तो सर्वलेट्स के साथ एक अच्छी ड्राइव के लिए अपने बेल्ट को जकड़ें। मुझे यकीन है कि आप इस ट्यूटोरियल का आनंद लेने जा रहे हैं।
एक विकास का वातावरण वह है जहाँ आप अपने सर्वलेट को विकसित करेंगे, उनका परीक्षण करेंगे और अंत में उन्हें चलाएंगे।
किसी भी अन्य जावा प्रोग्राम की तरह, आपको जावा कंपाइलर का उपयोग करके एक सर्वलेट संकलित करने की आवश्यकता है javac और सर्वलेट एप्लिकेशन के संकलन के बाद, इसे परीक्षण और चलाने के लिए एक कॉन्फ़िगर वातावरण में तैनात किया जाएगा।
इस विकास पर्यावरण सेटअप में निम्नलिखित चरण शामिल हैं -
जावा डेवलपमेंट किट की स्थापना
इस कदम में जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) का कार्यान्वयन डाउनलोड करना और उचित रूप से पाथ पर्यावरण चर को स्थापित करना शामिल है।
आप एसडीके को ओरेकल के जावा साइट - जावा एसई डाउनलोड से डाउनलोड कर सकते हैं ।
एक बार जब आप अपने जावा कार्यान्वयन को डाउनलोड करते हैं, तो सेटअप को स्थापित करने और कॉन्फ़िगर करने के लिए दिए गए निर्देशों का पालन करें। अंत में PATH और JAVA_HOME वातावरण चर को उस निर्देशिका के संदर्भ में सेट करें जिसमें क्रमशः java और javac शामिल हैं, आमतौर पर java_install_dir / bin और java_install_dir।
यदि आप Windows चला रहे हैं और SDK को C: \ jdk1.8.0_65 में स्थापित कर रहे हैं, तो आप अपनी C: \ autoexec.bat फ़ाइल में निम्न पंक्ति डालेंगे।
set PATH = C:\jdk1.8.0_65\bin;%PATH%
set JAVA_HOME = C:\jdk1.8.0_65
वैकल्पिक रूप से, Windows NT / 2000 / XP पर, आप My Computer पर राइट-क्लिक भी कर सकते हैं, गुण, फिर उन्नत, फिर पर्यावरण चर। फिर, आप पथ मूल्य को अपडेट करेंगे और ओके बटन दबाएंगे।
यूनिक्स (सोलारिस, लिनक्स, आदि) पर, यदि SDK /usr/local/jdk1.8.0_65 में स्थापित है और आप C शेल का उपयोग करते हैं, तो आप निम्नलिखित को अपनी .cshrc फ़ाइल में डाल देंगे।
setenv PATH /usr/local/jdk1.8.0_65/bin:$PATH
setenv JAVA_HOME /usr/local/jdk1.8.0_65
वैकल्पिक रूप से, यदि आप Borland JBuilder, Eclipse, IntelliJ IDEA, या Sun ONE स्टूडियो जैसे एक एकीकृत विकास पर्यावरण (IDE) का उपयोग करते हैं, तो यह पुष्टि करने के लिए एक साधारण प्रोग्राम संकलित करें और चलाएं कि IDE जानता है कि आपने जावा कहाँ स्थापित किया है।
वेब सर्वर की स्थापना - टॉमकैट
कई वेब सर्वर जो सर्विसलेट का समर्थन करते हैं, वे बाजार में उपलब्ध हैं। कुछ वेब सर्वर स्वतंत्र रूप से डाउनलोड करने योग्य हैं और टॉमकैट उनमें से एक है।
Apache Tomcat जावा सर्वलेट और जावा सर्वर पेजेस तकनीकों का एक खुला स्रोत सॉफ्टवेयर कार्यान्वयन है और यह सर्वलेट परीक्षण के लिए एक स्टैंडअलोन सर्वर के रूप में कार्य कर सकता है और इसे Apache वेब सर्वर के साथ एकीकृत किया जा सकता है। यहाँ अपने मशीन पर Tomcat सेटअप करने के लिए कदम हैं -
से Tomcat का नवीनतम संस्करण डाउनलोड करें https://tomcat.apache.org/।
एक बार जब आप इंस्टॉलेशन डाउनलोड कर लेते हैं, तो बाइनरी वितरण को सुविधाजनक स्थान पर अनपैक कर दें। उदाहरण के लिए C: \ Apache-tomcat-8.0.28 विंडोज़ पर, या /usr/local/apache-tomcat-8.0.289 लिनक्स / यूनिक्स पर और इन स्थानों की ओर इशारा करते हुए CATALINA_HOME पर्यावरण चर बनाएं।
विन्डोज़ मशीन पर निम्नलिखित कमांड निष्पादित करके टॉमकैट शुरू किया जा सकता है -
%CATALINA_HOME%\bin\startup.bat
or
C:\apache-tomcat-8.0.28\bin\startup.bat
यूनिक्स (सोलारिस, लिनक्स, आदि) मशीन पर निम्नलिखित आदेशों को निष्पादित करके टॉमकैट शुरू किया जा सकता है -
$CATALINA_HOME/bin/startup.sh
or
/usr/local/apache-tomcat-8.0.28/bin/startup.sh
स्टार्टअप के बाद, टॉमकैट के साथ शामिल डिफ़ॉल्ट वेब एप्लिकेशन पर जाकर उपलब्ध होंगे http://localhost:8080/। यदि सब कुछ ठीक है, तो इसे निम्नलिखित परिणाम प्रदर्शित करना चाहिए -
टॉमकैट को कॉन्फ़िगर करने और चलाने के बारे में अधिक जानकारी यहाँ शामिल प्रलेखन में पाई जा सकती है, साथ ही टॉमकैट वेब साइट पर भी - http://tomcat.apache.org
विन्डोज़ मशीन पर निम्नलिखित कमांड निष्पादित करके टॉमकैट को रोका जा सकता है -
C:\apache-tomcat-8.0.28\bin\shutdown
यूनिक्स (सोलारिस, लिनक्स, आदि) मशीन पर निम्नलिखित आदेशों को निष्पादित करके टॉमकैट को रोका जा सकता है -
/usr/local/apache-tomcat-8.0.28/bin/shutdown.sh
CLASSPATH की स्थापना
चूंकि सर्वलेट्स जावा प्लेटफॉर्म, स्टैंडर्ड एडिशन का हिस्सा नहीं हैं, इसलिए आपको सर्वलेट क्लासेस को कंपाइलर की पहचान करनी चाहिए।
यदि आप Windows चला रहे हैं, तो आपको अपनी C: \ autoexec.bat फ़ाइल में निम्न पंक्तियाँ डालनी होंगी।
set CATALINA = C:\apache-tomcat-8.0.28
set CLASSPATH = %CATALINA%\common\lib\servlet-api.jar;%CLASSPATH%
वैकल्पिक रूप से, Windows NT / 2000 / XP पर, आप मेरे कंप्यूटर पर जा सकते हैं -> गुण -> उन्नत -> पर्यावरण चर। फिर, आप CLASSPATH मान को अपडेट करेंगे और ओके बटन दबाएंगे।
यूनिक्स (सोलारिस, लिनक्स, आदि) पर, यदि आप सी शेल का उपयोग कर रहे हैं, तो आप निम्न पंक्तियों को अपने .crc फ़ाइल में डाल सकते हैं।
setenv CATALINA = /usr/local/apache-tomcat-8.0.28
setenv CLASSPATH $CATALINA/common/lib/servlet-api.jar:$CLASSPATH
NOTE - मान लें कि आपकी विकास निर्देशिका C: \ ServletDevel (Windows) या / usr / ServletDevel (Unix) है तो आपको इन निर्देशिकाओं को CLASSPATH में उसी तरह जोड़ना होगा जैसे आपने ऊपर जोड़ा है।
एक सर्वलेट जीवन चक्र को विनाश से इसके निर्माण तक की पूरी प्रक्रिया के रूप में परिभाषित किया जा सकता है। एक सर्वलेट के बाद आने वाले रास्ते निम्नलिखित हैं।
सर्वलेट को कॉल करके आरंभ किया गया है init() तरीका।
सर्वलेट कॉल करता है service() ग्राहक के अनुरोध को संसाधित करने की विधि।
सर्वलेट को कॉल करके समाप्त किया जाता है destroy() तरीका।
अंत में, सर्वलेट जेवीएम के कचरा कलेक्टर द्वारा एकत्र किया गया कचरा है।
अब हम जीवन चक्र विधियों पर विस्तार से चर्चा करते हैं।
Init () विधि
Init विधि को केवल एक बार कहा जाता है। यह केवल तभी कहा जाता है जब सर्वलेट बनाया जाता है, और बाद में किसी भी उपयोगकर्ता के अनुरोध के लिए नहीं बुलाया जाता है। तो, इसका उपयोग एक-बार के आरंभीकरण के लिए किया जाता है, जिस तरह एप्लेट्स की init पद्धति से।
सर्वलेट आम तौर पर तब बनाया जाता है जब कोई उपयोगकर्ता सर्वप्रथम किसी सर्वलेट के यूआरएल को इनवॉइस करता है, लेकिन आप यह भी निर्दिष्ट कर सकते हैं कि सर्वर के शुरू होने पर सर्वलेट को लोड किया जाए।
जब कोई उपयोगकर्ता किसी सर्वलेट को आमंत्रित करता है, तो प्रत्येक सर्वलेट का एक एकल उदाहरण बन जाता है, प्रत्येक उपयोगकर्ता अनुरोध के परिणामस्वरूप एक नया थ्रेड जो doGet या doPost को उपयुक्त के रूप में दिया जाता है। Init () विधि बस कुछ डेटा बनाता है या लोड करता है जो सर्वलेट के पूरे जीवन में उपयोग किया जाएगा।
Init विधि की परिभाषा इस प्रकार है -
public void init() throws ServletException {
// Initialization code...
}
सेवा () विधि
सेवा () विधि वास्तविक कार्य करने के लिए मुख्य विधि है। सर्वलेट कंटेनर (यानी वेब सर्वर) क्लाइंट (ब्राउज़र) से आने वाले अनुरोधों को संभालने के लिए सेवा () विधि को कॉल करता है और क्लाइंट को स्वरूपित प्रतिक्रिया को लिखने के लिए।
हर बार सर्वर को एक सर्वलेट के लिए अनुरोध प्राप्त होता है, सर्वर एक नया धागा पैदा करता है और सेवा को कॉल करता है। सेवा () विधि HTTP अनुरोध प्रकार (GET, POST, PUT, DELETE, आदि) की जांच करती है और doGet, doPost, doPut, doDelete, आदि विधियों को उपयुक्त कहती है।
यहाँ इस विधि के हस्ताक्षर हैं -
public void service(ServletRequest request, ServletResponse response)
throws ServletException, IOException {
}
कंटेनर द्वारा सेवा () विधि को बुलाया जाता है और सेवा विधि उचित रूप में doGet, doPost, doPut, doDelete, आदि विधियों को आमंत्रित करती है। इसलिए आपको सेवा () विधि से कोई लेना-देना नहीं है लेकिन आप ग्राहक से प्राप्त होने वाले अनुरोध के आधार पर या तो doGet () या doPost () को ओवरराइड करते हैं।
DoGet () और doPost () प्रत्येक सेवा अनुरोध के साथ सबसे अधिक बार उपयोग की जाने वाली विधियाँ हैं। यहाँ इन दो विधियों के हस्ताक्षर हैं।
DoGet () विधि
URL के लिए एक सामान्य अनुरोध से या किसी HTML फॉर्म से कोई GET अनुरोध प्राप्त होता है जिसमें कोई METHOD निर्दिष्ट नहीं है और इसे doGet () विधि द्वारा नियंत्रित किया जाना चाहिए।
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Servlet code
}
DoPost () विधि
एक POST अनुरोध HTML फॉर्म से परिणाम प्राप्त करता है जो विशेष रूप से POST को METHOD के रूप में सूचीबद्ध करता है और इसे doPost () विधि द्वारा नियंत्रित किया जाना चाहिए।
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Servlet code
}
नष्ट () विधि
नष्ट () पद्धति को सर्वलेट के जीवन चक्र के अंत में केवल एक बार कहा जाता है। यह विधि आपके सर्वलेट को डेटाबेस कनेक्शन बंद करने, बैकग्राउंड थ्रेड्स को बंद करने, कुकी सूचियों को लिखने या डिस्क पर हिट काउंट्स, और इस तरह की अन्य सफाई गतिविधियों को करने का मौका देती है।
नष्ट () विधि कहा जाता है के बाद, सर्वलेट ऑब्जेक्ट को कचरा संग्रह के लिए चिह्नित किया जाता है। विध्वंस विधि की परिभाषा इस तरह दिखती है -
public void destroy() {
// Finalization code...
}
वास्तुकला आरेख
निम्न आकृति में एक सामान्य सर्वलेट जीवन-चक्र परिदृश्य को दर्शाया गया है।
पहले सर्वर पर आने वाले HTTP रिक्वेस्ट को सर्वलेट कंटेनर में दिया जाता है।
सर्वलेट कंटेनर सर्विस () विधि को लागू करने से पहले सर्वलेट को लोड करता है।
फिर सर्वलेट कंटेनर कई थ्रेड्स को थूक कर कई अनुरोधों को संभालता है, प्रत्येक थ्रेड सर्वलेट के एकल उदाहरण की सेवा () पद्धति को निष्पादित करता है।
सर्वलेट्स जावा क्लासेस हैं जो HTTP अनुरोधों को सेवा प्रदान करती हैं और कार्यान्वित करती हैं javax.servlet.Servletइंटरफेस। वेब एप्लिकेशन डेवलपर आमतौर पर सर्वलेट्स लिखते हैं जो javax.servlet.http.HttpServlet का विस्तार करते हैं, एक सार वर्ग जो सर्वलेट इंटरफ़ेस को लागू करता है और विशेष रूप से HTTP अनुरोधों को संभालने के लिए डिज़ाइन किया गया है।
नमूना कोड
हैलो वर्ल्ड दिखाने के लिए सर्वलेट उदाहरण का नमूना स्रोत कोड संरचना निम्नलिखित है -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class HelloWorld extends HttpServlet {
private String message;
public void init() throws ServletException {
// Do required initialization
message = "Hello World";
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
// Actual logic goes here.
PrintWriter out = response.getWriter();
out.println("<h1>" + message + "</h1>");
}
public void destroy() {
// do nothing.
}
}
एक सर्वलेट संकलन
हमें ऊपर दिखाए गए कोड के साथ HelloWorld.java नाम से एक फाइल बनाते हैं। इस फ़ाइल को C: \ ServletDevel (विंडोज़ में) या / usr / ServletDevel (यूनिक्स में) पर रखें। आगे बढ़ने से पहले इस पथ स्थान को CLASSPATH में जोड़ा जाना चाहिए।
मान लें कि आपका वातावरण ठीक से सेटअप है, तो अंदर जाएं ServletDevel निर्देशिका और HelloWorld.java का संकलन इस प्रकार है -
$ javac HelloWorld.java
यदि सर्वलेट किसी अन्य लाइब्रेरी पर निर्भर करता है, तो आपको उन JAR फ़ाइलों को अपने CLASSPATH पर भी शामिल करना होगा। मैंने केवल सर्वलेट-एपी.जर जार फाइल को शामिल किया है क्योंकि मैं हैलो वर्ल्ड कार्यक्रम में किसी अन्य पुस्तकालय का उपयोग नहीं कर रहा हूं।
यह कमांड लाइन बिल्ट-इन जेवैक कंपाइलर का उपयोग करता है जो सन माइक्रोसिस्टम्स जावा सॉफ्टवेयर डेवलपमेंट किट (JDK) के साथ आता है। इस आदेश को ठीक से काम करने के लिए, आपको जावा एसडीके के स्थान को शामिल करना होगा जिसे आप पाथ पर्यावरण चर में उपयोग कर रहे हैं।
यदि सब कुछ ठीक हो जाता है, तो ऊपर संकलन का उत्पादन होगा HelloWorld.classउसी निर्देशिका में फ़ाइल। अगला खंड बताता है कि उत्पादन में एक संकलित सर्वलेट कैसे तैनात किया जाएगा।
सर्वलेट तैनाती
डिफ़ॉल्ट रूप से, एक सर्वलेट एप्लिकेशन पथ पर स्थित है <Tomcat-setupdirectory> / webapps / ROOT और वर्ग फ़ाइल <Tomcat-installationdirectory> / webapp / ROOT / WEB-INF / कक्षाओं में निवास करेगा।
यदि आपके पास पूरी तरह से योग्य वर्ग का नाम है com.myorg.MyServlet, तब यह सर्वलेट क्लास WEB-INF / classes / com / myorg / MyServlet.class में स्थित होना चाहिए।
अभी के लिए, हमें HelloWorld.class को <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / कक्षाओं में कॉपी करें और निम्नलिखित प्रविष्टियों को बनाएँ web.xml <Tomcat-installation-directory> / webapps / ROOT / WEB-INF / में स्थित फ़ाइल
<servlet>
<servlet-name>HelloWorld</servlet-name>
<servlet-class>HelloWorld</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloWorld</servlet-name>
<url-pattern>/HelloWorld</url-pattern>
</servlet-mapping>
उपरोक्त प्रविष्टियाँ <web-app> ... </ web-app> टैग के लिए web.xml फ़ाइल में उपलब्ध हैं। इस तालिका में पहले से ही उपलब्ध विभिन्न प्रविष्टियाँ हो सकती हैं, लेकिन कोई बात नहीं।
आप लगभग पूर्ण हो चुके हैं, अब हम टॉमकैट सर्वर को <Tomcat-installationdirectory> \ bin \ स्टार्टअप.bat (विंडोज पर) या <Tomcat-setupdirectory> /bin/startup.sh (लिनक्स / सोलारिस आदि) और अंत में टाइप का उपयोग करके शुरू करते हैं। http://localhost:8080/HelloWorldब्राउज़र के एड्रेस बॉक्स में। यदि सब कुछ ठीक रहा, तो आपको निम्नलिखित परिणाम प्राप्त होंगे
जब आप अपने ब्राउज़र से वेब सर्वर और अंत में अपने बैकएंड प्रोग्राम में कुछ जानकारी पास करने की आवश्यकता होती है, तो आप कई स्थितियों में आ गए होंगे। वेब सर्वर पर इस जानकारी को पास करने के लिए ब्राउज़र दो तरीकों का उपयोग करता है। ये तरीके हैं GET मेथड और POST मेथड।
विधि प्राप्त करें
GET विधि पेज अनुरोध के लिए संलग्न एन्कोडेड उपयोगकर्ता जानकारी भेजता है। पृष्ठ और एन्कोडेड जानकारी को अलग कर दिया जाता है? (प्रश्न चिह्न) प्रतीक इस प्रकार है -
http://www.test.com/hello?key1 = value1&key2 = value2
जीईटी विधि ब्राउज़र से वेब सर्वर तक जानकारी पारित करने के लिए डिफ़ॉल्ट विधि है और यह आपके ब्राउज़र के स्थान: बॉक्स में दिखाई देने वाली लंबी स्ट्रिंग का उत्पादन करती है। यदि आपके पास सर्वर के पास जाने के लिए पासवर्ड या अन्य संवेदनशील जानकारी है तो कभी भी GET विधि का उपयोग न करें। GET विधि का आकार सीमा है: अनुरोध स्ट्रिंग में केवल 1024 वर्णों का उपयोग किया जा सकता है।
यह जानकारी QUERY_STRING हेडर का उपयोग करके पास की गई है और QUERY_STRING वातावरण चर के माध्यम से सुलभ होगी और सर्वलेट इस प्रकार के अनुरोधों का उपयोग करके संभालता है doGet() तरीका।
पोस्ट विधि
आम तौर पर बैकएंड प्रोग्राम को जानकारी देने का एक अधिक विश्वसनीय तरीका POST विधि है। यह सूचना को GET विधि की तरह ही पैकेज करता है, लेकिन इसके बाद इसे टेक्स्ट स्ट्रिंग के रूप में भेजने के बजाय? (प्रश्न चिह्न) URL में इसे एक अलग संदेश के रूप में भेजता है। यह संदेश मानक इनपुट के रूप में बैकेंड प्रोग्राम में आता है जिसे आप पार्स कर सकते हैं और अपने प्रसंस्करण के लिए उपयोग कर सकते हैं। सर्वलेट इस प्रकार के अनुरोधों का उपयोग करके संभालता हैdoPost() तरीका।
सर्वलेट का उपयोग करके फॉर्म डेटा पढ़ना
सर्वलेट्स स्थिति के आधार पर निम्न विधियों का उपयोग करके स्वचालित रूप से डेटा पार्सिंग को संभालते हैं -
getParameter() - आप फॉर्म पैरामीटर का मान प्राप्त करने के लिए request.getParameter () विधि कहते हैं।
getParameterValues() - यदि पैरामीटर एक से अधिक बार दिखाई देता है और कई मान लौटाता है, तो इस विधि को कॉल करें, उदाहरण के लिए चेकबॉक्स।
getParameterNames() - इस विधि को कॉल करें यदि आप वर्तमान अनुरोध में सभी मापदंडों की पूरी सूची चाहते हैं।
URL का उपयोग करके विधि का उदाहरण प्राप्त करें
यहाँ एक सरल URL है जो GET विधि का उपयोग करके HelloForm प्रोग्राम में दो मानों को पास करेगा।
http://localhost:8080/HelloForm?first_name = ZARA&last_name = ALIनीचे दिया गया है HelloForm.javaवेब ब्राउज़र द्वारा दिए गए इनपुट को संभालने के लिए सर्वलेट प्रोग्राम। हम उपयोग करने जा रहे हैंgetParameter() वह विधि जिससे उत्तीर्ण जानकारी तक पहुँचना बहुत आसान हो जाता है -
// 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 {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Using GET Method to Read Form Data";
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.java को इस प्रकार संकलित करें -
$ javac HelloForm.java
यदि सब कुछ ठीक हो जाता है, तो ऊपर संकलन का उत्पादन होगा HelloForm.classफ़ाइल। इसके बाद आपको इस कक्षा की फ़ाइल को <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / कक्षाओं में कॉपी करना होगा और निम्नलिखित प्रविष्टियों को बनाना होगा।web.xml <Tomcat-installation-directory> / webapps / ROOT / WEB-INF / में स्थित फ़ाइल
<servlet>
<servlet-name>HelloForm</servlet-name>
<servlet-class>HelloForm</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloForm</servlet-name>
<url-pattern>/HelloForm</url-pattern>
</servlet-mapping>
अब http: // localhost: 8080 / HelloForm टाइप करें? अपने ब्राउज़र के स्थान में ? पहले से कनेक्ट करें और सुनिश्चित करें कि आपने ब्राउज़र में कमांड के ऊपर फायरिंग करने से पहले, सुनिश्चित करें कि आपने पहले ही टॉमकैट सर्वर शुरू कर दिया है। यह निम्नलिखित परिणाम उत्पन्न करेगा -
Using GET Method to Read Form Data
- First Name: ZARA
- Last Name: ALI
फॉर्म का उपयोग करके विधि प्राप्त करें
यहां एक सरल उदाहरण दिया गया है जो HTML FORM और सबमिट बटन का उपयोग करके दो मानों को पार करता है। हम इस इनपुट को संभालने के लिए एक ही सर्वलेट HelloForm का उपयोग करने जा रहे हैं।
<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>
इस HTML को एक Hello.htm फ़ाइल में रखें और इसे <Tomcat-installationdirectory> / webapps / ROOT निर्देशिका में डालें। जब आप http: // localhost: 8080 / Hello.htm को एक्सेस करेंगे , तो यहां उपरोक्त फॉर्म का वास्तविक आउटपुट है।
पहले नाम और अंतिम नाम दर्ज करने का प्रयास करें और फिर अपने स्थानीय मशीन पर परिणाम देखने के लिए सबमिट बटन पर क्लिक करें जहां टॉमकैट चल रहा है। दिए गए इनपुट के आधार पर, यह उपरोक्त उदाहरण में उल्लिखित समान परिणाम उत्पन्न करेगा।
POST विधि उदाहरण फॉर्म का उपयोग करना
आइए हम उपरोक्त सर्वलेट में थोड़ा संशोधन करें, ताकि यह GET के साथ-साथ POST विधियों को भी संभाल सके। नीचे हैHelloForm.java GET या POST विधियों का उपयोग करके वेब ब्राउज़र द्वारा दिए गए इनपुट को संभालने के लिए सर्वलेट प्रोग्राम।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class HelloForm extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Using GET Method to Read Form Data";
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>"
);
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब उपरोक्त सर्वलेट को संकलित करें और तैनात करें और POST पद्धति के साथ हैलो.टम का उपयोग करके इसका परीक्षण करें -
<html>
<body>
<form action = "HelloForm" method = "POST">
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>
यहां ऊपर दिए गए फॉर्म का वास्तविक आउटपुट है, फर्स्ट और लास्ट नेम एंटर करने की कोशिश करें और फिर सबमिट बटन पर क्लिक करके अपने लोकल मशीन पर रिजल्ट देखें जहां टॉमकैट चल रहा है।
प्रदान किए गए इनपुट के आधार पर, यह उपरोक्त उदाहरणों में उल्लिखित समान परिणाम उत्पन्न करेगा।
सर्वलेट प्रोग्राम में चेकबॉक्स डेटा पास करना
चेकबॉक्स का उपयोग तब किया जाता है जब एक से अधिक विकल्प चुनने की आवश्यकता होती है।
यहाँ उदाहरण के लिए दो चेकबॉक्स के साथ HTML कोड, CheckBox.htm है
<html>
<body>
<form action = "CheckBox" method = "POST" target = "_blank">
<input type = "checkbox" name = "maths" checked = "checked" /> Maths
<input type = "checkbox" name = "physics" /> Physics
<input type = "checkbox" name = "chemistry" checked = "checked" />
Chemistry
<input type = "submit" value = "Select Subject" />
</form>
</body>
</html>
इस कोड का परिणाम निम्न रूप है
नीचे दिया गया चेकबॉक्स बटन के लिए वेब ब्राउज़र द्वारा दिए गए इनपुट को संभालने के लिए CheckBox.java सर्वलेट प्रोग्राम है।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class CheckBox extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Reading Checkbox Data";
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>Maths Flag : </b>: "
+ request.getParameter("maths") + "\n" +
" <li><b>Physics Flag: </b>: "
+ request.getParameter("physics") + "\n" +
" <li><b>Chemistry Flag: </b>: "
+ request.getParameter("chemistry") + "\n" +
"</ul>\n" +
"</body>"
"</html>"
);
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
उपरोक्त उदाहरण के लिए, यह निम्नलिखित परिणाम प्रदर्शित करेगा -
Reading Checkbox Data
- Maths Flag : : on
- Physics Flag: : null
- Chemistry Flag: : on
ऑल फॉर्म पैरामीटर्स पढ़ना
निम्नलिखित सामान्य उदाहरण है जो उपयोग करता है getParameterNames()सभी उपलब्ध प्रपत्र मापदंडों को पढ़ने के लिए HttpServletRequest की विधि। यह विधि एक Enumeration देता है जिसमें कोई अनिर्दिष्ट क्रम में पैरामीटर नाम होते हैं
एक बार हमारे पास एन्यूमरेशन होने के बाद, हम प्रत्येक पैरामीटर का नाम प्राप्त करने के लिए नेममेंट () विधि को रोकने और उपयोग करने के लिए निर्धारित करने के लिए hasMoreElements () विधि का उपयोग करके मानक तरीके से एन्यूमरेशन को कम कर सकते हैं ।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class ReadParams extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Reading All Form Parameters";
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" +
"<table width = \"100%\" border = \"1\" align = \"center\">\n" +
"<tr bgcolor = \"#949494\">\n" +
"<th>Param Name</th>"
"<th>Param Value(s)</th>\n"+
"</tr>\n"
);
Enumeration paramNames = request.getParameterNames();
while(paramNames.hasMoreElements()) {
String paramName = (String)paramNames.nextElement();
out.print("<tr><td>" + paramName + "</td>\n<td>");
String[] paramValues = request.getParameterValues(paramName);
// Read single valued data
if (paramValues.length == 1) {
String paramValue = paramValues[0];
if (paramValue.length() == 0)
out.println("<i>No Value</i>");
else
out.println(paramValue);
} else {
// Read multiple valued data
out.println("<ul>");
for(int i = 0; i < paramValues.length; i++) {
out.println("<li>" + paramValues[i]);
}
out.println("</ul>");
}
}
out.println("</tr>\n</table>\n</body></html>");
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब, निम्नलिखित फॉर्म के साथ उपरोक्त सर्वलेट की कोशिश करें -
<html>
<body>
<form action = "ReadParams" method = "POST" target = "_blank">
<input type = "checkbox" name = "maths" checked = "checked" /> Maths
<input type = "checkbox" name = "physics" /> Physics
<input type = "checkbox" name = "chemistry" checked = "checked" /> Chem
<input type = "submit" value = "Select Subject" />
</form>
</body>
</html>
अब उपरोक्त फॉर्म का उपयोग करके सर्वलेट कॉल करने से निम्नलिखित परिणाम उत्पन्न होंगे -
Reading All Form Parameters
Param Name
Param Value(s)
maths
on
chemistry
on
आप उपरोक्त सर्वलेट को किसी भी अन्य फॉर्म के डेटा को पढ़ने के लिए आज़मा सकते हैं, जैसे अन्य वस्तुएं जैसे टेक्स्ट बॉक्स, रेडियो बटन या ड्रॉप डाउन बॉक्स आदि।
जब कोई ब्राउज़र वेब पेज के लिए अनुरोध करता है, तो यह वेब सर्वर को बहुत सारी जानकारी भेजता है जिसे सीधे नहीं पढ़ा जा सकता क्योंकि यह जानकारी HTTP अनुरोध के हेडर के एक भाग के रूप में यात्रा करती है। इस बारे में अधिक जानकारी के लिए आप HTTP प्रोटोकॉल की जांच कर सकते हैं ।
निम्नलिखित महत्वपूर्ण हेडर जानकारी है जो ब्राउज़र साइड से आती है और आप वेब प्रोग्रामिंग में बहुत बार उपयोग करेंगे -
अनु क्रमांक। | हेडर और विवरण |
---|---|
1 | Accept यह हेडर MIME प्रकार निर्दिष्ट करता है जिसे ब्राउज़र या अन्य क्लाइंट संभाल सकते हैं। का मानimage/png या image/jpeg दो सबसे आम संभावनाएं हैं। |
2 | Accept-Charset यह हैडर निर्दिष्ट करता है कि वह चरित्र सेट करता है जिसे ब्राउज़र सूचना का उपयोग करने के लिए कर सकता है। उदाहरण के लिए ISO-8859-1। |
3 | Accept-Encoding यह शीर्ष लेख एन्कोडिंग के प्रकारों को निर्दिष्ट करता है जो ब्राउज़र जानता है कि कैसे संभालना है। का मानgzip या compress दो सबसे आम संभावनाएं हैं। |
4 | Accept-Language यह हेडर क्लाइंट की पसंदीदा भाषाओं को निर्दिष्ट करता है, जब सर्वलेट एक से अधिक भाषाओं में परिणाम उत्पन्न कर सकता है। उदाहरण के लिए एन, एन-यू, आरयू, आदि |
5 | Authorization पासवर्ड-सुरक्षित वेब पेजों को एक्सेस करने के दौरान क्लाइंट द्वारा स्वयं की पहचान करने के लिए इस हेडर का उपयोग किया जाता है। |
6 | Connection यह शीर्षलेख इंगित करता है कि क्या क्लाइंट लगातार HTTP कनेक्शन संभाल सकता है। लगातार कनेक्शन क्लाइंट या अन्य ब्राउज़र को एक ही अनुरोध के साथ कई फ़ाइलों को पुनः प्राप्त करने की अनुमति देते हैं। का एक मूल्यKeep-Alive इसका मतलब है कि लगातार कनेक्शन का उपयोग किया जाना चाहिए। |
7 | Content-Length यह शीर्षलेख केवल POST अनुरोधों पर लागू होता है और बाइट्स में POST डेटा का आकार देता है। |
8 | Cookie यह हेडर कुकीज़ को उन सर्वरों पर लौटाता है जो पहले उन्हें ब्राउज़र में भेजे थे। |
9 | Host यह हैडर मूल URL में दिए अनुसार होस्ट और पोर्ट को निर्दिष्ट करता है। |
10 | If-Modified-Since यह शीर्षलेख इंगित करता है कि क्लाइंट केवल पृष्ठ को चाहता है यदि इसे निर्दिष्ट तिथि के बाद बदल दिया गया हो। सर्वर एक कोड भेजता है, 304 जिसका अर्थ हैNot Modified हेडर अगर कोई नया परिणाम उपलब्ध नहीं है। |
1 1 | If-Unmodified-Since यह हेडर अगर-मॉडिफाइड-चूंकि का रिवर्स है; यह निर्दिष्ट करता है कि ऑपरेशन केवल तभी सफल होना चाहिए जब दस्तावेज़ निर्दिष्ट तिथि से पुराना हो। |
12 | Referer यह शीर्ष लेख संदर्भित वेब पेज के URL को दर्शाता है। उदाहरण के लिए, यदि आप वेब पेज 1 पर हैं और वेब पेज 2 के लिंक पर क्लिक करते हैं, तो वेब पेज 1 का URL तब संदर्भित होता है जब ब्राउज़र वेब पेज 2 का अनुरोध करता है। |
13 | User-Agent यह हेडर अनुरोध करने वाले ब्राउज़र या अन्य क्लाइंट की पहचान करता है और इसका उपयोग विभिन्न प्रकार के ब्राउज़रों को विभिन्न सामग्री वापस करने के लिए किया जा सकता है। |
HTTP हेडर पढ़ने के तरीके
निम्नलिखित तरीके हैं जो आपके सर्वलेट प्रोग्राम में HTTP हेडर पढ़ने के लिए उपयोग किए जा सकते हैं। ये तरीके HttpServletRequest ऑब्जेक्ट के साथ उपलब्ध हैं
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Cookie[] getCookies() इस अनुरोध के साथ भेजे गए क्लाइंट की सभी ऑब्जेक्ट वाली सरणी लौटाता है। |
2 | Enumeration getAttributeNames() इस अनुरोध के लिए उपलब्ध विशेषताओं के नाम वाले एन्यूमरेशन को लौटाता है। |
3 | Enumeration getHeaderNames() उन सभी शीर्ष लेखों के नाम शामिल करता है जिनमें यह अनुरोध होता है। |
4 | Enumeration getParameterNames() इस अनुरोध में शामिल मानकों के नाम वाले स्ट्रिंग ऑब्जेक्ट्स का एन्यूमरेशन लौटाता है |
5 | HttpSession getSession() इस अनुरोध से संबंधित वर्तमान सत्र लौटाता है, या यदि अनुरोध में सत्र नहीं है, तो एक बनाता है। |
6 | HttpSession getSession(boolean create) इस अनुरोध के साथ जुड़े वर्तमान HttpSession रिटर्न या, अगर कोई मौजूदा सत्र नहीं है और बनाने का मूल्य सच है, एक नया सत्र लौटाता है। |
7 | Locale getLocale() स्वीकार-भाषा हेडर के आधार पर ग्राहक को पसंदीदा लोकेल लौटाता है, जिसमें सामग्री को स्वीकार किया जाएगा। |
8 | Object getAttribute(String name) यदि दिए गए नाम की कोई विशेषता मौजूद नहीं है, तो नामित विशेषता का मान किसी ऑब्जेक्ट या नल के रूप में लौटाता है। |
9 | ServletInputStream getInputStream() एक ServletInputStream का उपयोग करके बाइनरी डेटा के रूप में अनुरोध का मुख्य भाग पुनर्प्राप्त करता है। |
10 | String getAuthType() सर्वलेट की सुरक्षा के लिए उपयोग की जाने वाली प्रमाणीकरण योजना का नाम लौटाता है, उदाहरण के लिए, "BASIC" या "SSL", या यदि JSP संरक्षित नहीं था तो अशक्त है। |
1 1 | String getCharacterEncoding() इस अनुरोध के शरीर में उपयोग किए गए वर्ण एन्कोडिंग का नाम देता है। |
12 | String getContentType() अनुरोध के निकाय के MIME प्रकार को लौटाता है, या यदि प्रकार ज्ञात नहीं है, तो अशक्त है। |
13 | String getContextPath() URI अनुरोध के भाग को लौटाता है जो अनुरोध के संदर्भ को इंगित करता है। |
14 | String getHeader(String name) स्ट्रिंग के रूप में निर्दिष्ट अनुरोध हैडर का मान लौटाता है। |
15 | String getMethod() HTTP विधि का नाम देता है जिसके साथ यह अनुरोध किया गया था, उदाहरण के लिए, GET, POST या PUT। |
16 | String getParameter(String name) यदि कोई पैरामीटर मौजूद नहीं है, तो स्ट्रिंग के रूप में अनुरोध पैरामीटर का मान लौटाता है या अशक्त होता है। |
17 | String getPathInfo() जब यह अनुरोध किया जाता है तो क्लाइंट द्वारा भेजे गए URL से जुड़ी कोई भी अतिरिक्त पथ जानकारी देता है |
18 | String getProtocol() अनुरोध के प्रोटोकॉल का नाम और संस्करण लौटाता है। |
19 | String getQueryString() पथ के बाद अनुरोध URL में निहित क्वेरी स्ट्रिंग लौटाता है। |
20 | String getRemoteAddr() अनुरोध भेजने वाले क्लाइंट का इंटरनेट प्रोटोकॉल (IP) पता लौटाता है। |
21 | String getRemoteHost() अनुरोध भेजने वाले क्लाइंट का पूरी तरह से योग्य नाम लौटाता है। |
22 | String getRemoteUser() यह अनुरोध करते हुए उपयोगकर्ता का लॉगिन लौटाता है, यदि उपयोगकर्ता प्रमाणित नहीं किया गया है या उपयोगकर्ता प्रमाणित नहीं किया गया है, तो इसे रद्द कर दें। |
23 | String getRequestURI() HTTP अनुरोध के पहले पंक्ति में प्रोटोकॉल नाम से क्वेरी स्ट्रिंग तक इस अनुरोध के URL का हिस्सा लौटाता है। |
24 | String getRequestedSessionId() क्लाइंट द्वारा निर्दिष्ट सत्र आईडी लौटाता है। |
25 | String getServletPath() इस अनुरोध के URL का वह भाग लौटाता है जो JSP को कॉल करता है। |
26 | String[] getParameterValues(String name) दिए गए अनुरोध पैरामीटर के सभी मान वाले स्ट्रिंग ऑब्जेक्ट्स की एक सरणी देता है, अगर पैरामीटर मौजूद नहीं है, या रिक्त है। |
27 | boolean isSecure() एक बूलियन को इंगित करता है कि क्या यह अनुरोध एक सुरक्षित चैनल, जैसे कि HTTPS का उपयोग करके किया गया था। |
28 | int getContentLength() अनुरोध निकाय के बाइट्स में लंबाई लौटाता है, और इनपुट स्ट्रीम द्वारा उपलब्ध कराया जाता है, या -1 यदि लंबाई ज्ञात नहीं है। |
29 | int getIntHeader(String name) इंट के रूप में निर्दिष्ट अनुरोध हेडर का मान लौटाता है। |
30 | int getServerPort() पोर्ट नंबर देता है जिस पर यह अनुरोध प्राप्त हुआ था। |
HTTP हैडर अनुरोध उदाहरण
निम्नलिखित उदाहरण है जो उपयोग करता है getHeaderNames()HTTP हैडर जानकारी पढ़ने के लिए HttpServletRequest की विधि। यह विधि एक एन्यूमरेशन देता है जिसमें वर्तमान HTTP अनुरोध के साथ संबंधित हेडर जानकारी होती है।
एक बार हमारे पास एन्यूमरेशन होने के बाद, हम प्रत्येक पैरामीटर का नाम प्राप्त करने के लिए नेमेमेंट () और रुकने के तरीके का उपयोग करने के लिए निर्धारित करने के लिए hasMoreElements () विधि का उपयोग करते हुए मानक तरीके से एन्यूमरेशन को लूप कर सकते हैं।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class DisplayHeader extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "HTTP Header Request 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" +
"<table width = \"100%\" border = \"1\" align = \"center\">\n" +
"<tr bgcolor = \"#949494\">\n" +
"<th>Header Name</th><th>Header Value(s)</th>\n"+
"</tr>\n"
);
Enumeration headerNames = request.getHeaderNames();
while(headerNames.hasMoreElements()) {
String paramName = (String)headerNames.nextElement();
out.print("<tr><td>" + paramName + "</td>\n");
String paramValue = request.getHeader(paramName);
out.println("<td> " + paramValue + "</td></tr>\n");
}
out.println("</table>\n</body></html>");
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब उपरोक्त सर्वलेट को कॉल करने से निम्नलिखित परिणाम उत्पन्न होंगे -
HTTP Header Request Example
Header Name
Header Value(s)
accept
*/*
accept-language
en-us
user-agent
Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; InfoPath.2; MS-RTC LM 8)
accept-encoding
gzip, deflate
host
localhost:8080
connection
Keep-Alive
cache-control
no-cache
जैसा कि पिछले अध्याय में चर्चा की गई है, जब एक वेब सर्वर एक HTTP अनुरोध का जवाब देता है, तो प्रतिक्रिया में आमतौर पर एक स्थिति रेखा, कुछ प्रतिक्रिया शीर्षलेख, एक रिक्त रेखा और दस्तावेज़ होते हैं। एक विशिष्ट प्रतिक्रिया इस तरह दिखती है -
HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
(Blank Line)
<!doctype ...>
<html>
<head>...</head>
<body>
...
</body>
</html>
स्टेटस लाइन में HTTP वर्जन (उदाहरण में HTTP / 1.1), एक स्टेटस कोड (उदाहरण में 200) और स्टेटस कोड (उदाहरण में ओके) के अनुरूप एक बहुत छोटा संदेश होता है।
निम्नलिखित सबसे उपयोगी HTTP 1.1 प्रतिक्रिया हेडर का सारांश है जो वेब सर्वर की ओर से ब्राउज़र में वापस जाता है और आप वेब प्रोग्रामिंग में उनका बहुत बार उपयोग करेंगे -
अनु क्रमांक। | हेडर और विवरण |
---|---|
1 | Allow यह शीर्ष लेख अनुरोध विधियों (GET, POST, आदि) को निर्दिष्ट करता है जो सर्वर समर्थन करता है। |
2 | Cache-Control यह हेडर उन परिस्थितियों को निर्दिष्ट करता है जिसमें प्रतिक्रिया दस्तावेज़ सुरक्षित रूप से कैश किया जा सकता है। इसके मान हो सकते हैंpublic, private या no-cache आदि का अर्थ है कि सार्वजनिक दस्तावेज दस्तावेज़ उपलब्ध नहीं है, निजी साधन दस्तावेज़ एकल उपयोगकर्ता के लिए है और इसे केवल निजी (गैर-साझा) कैश में संग्रहीत किया जा सकता है और नोचे का अर्थ है कि दस्तावेज़ को कभी कैश नहीं किया जाना चाहिए। |
3 | Connection यह हेडर ब्राउज़र को निर्देश देता है कि क्या HTTP कनेक्शन में लगातार उपयोग करना है या नहीं। का एक मूल्यclose ब्राउज़र को लगातार HTTP कनेक्शन का उपयोग न करने का निर्देश देता है और keepalive लगातार कनेक्शन का उपयोग करने का मतलब है। |
4 | Content-Disposition यह हेडर आपको अनुरोध करता है कि ब्राउज़र उपयोगकर्ता को दिए गए नाम की फ़ाइल में डिस्क पर प्रतिक्रिया को बचाने के लिए कहें। |
5 | Content-Encoding यह शीर्ष लेख उस तरीके को निर्दिष्ट करता है जिसमें ट्रांसमिशन के दौरान पृष्ठ एन्कोड किया गया था। |
6 | Content-Language यह हेडर उस भाषा को दर्शाता है जिसमें दस्तावेज़ लिखा गया है। उदाहरण के लिए एन, एन-यू, आरयू, आदि |
7 | Content-Length यह हेडर प्रतिक्रिया में बाइट्स की संख्या को इंगित करता है। यह जानकारी केवल तभी आवश्यक है जब ब्राउज़र एक निरंतर (जीवित) HTTP कनेक्शन का उपयोग कर रहा है। |
8 | Content-Type यह हेडर प्रतिक्रिया दस्तावेज़ के MIME (बहुउद्देशीय इंटरनेट मेल एक्सटेंशन) प्रकार देता है। |
9 | Expires यह शीर्ष लेख उस समय को निर्दिष्ट करता है जिस पर सामग्री को पुराना माना जाना चाहिए और इस प्रकार अब कैश नहीं किया जाना चाहिए। |
10 | Last-Modified यह हेडर इंगित करता है कि दस्तावेज़ अंतिम बार कब बदला गया था। ग्राहक तब दस्तावेज़ को कैश कर सकता है और एक तारीख को आपूर्ति कर सकता हैIf-Modified-Since बाद के अनुरोधों में हेडर का अनुरोध करें। |
1 1 | Location इस हेडर को उन सभी प्रतिक्रियाओं के साथ शामिल किया जाना चाहिए जिनके पास 300 में एक स्थिति कोड है। यह दस्तावेज़ पते के ब्राउज़र को सूचित करता है। ब्राउज़र स्वचालित रूप से इस स्थान पर फिर से जुड़ता है और नए दस्तावेज़ को पुनः प्राप्त करता है। |
12 | Refresh यह शीर्ष लेख निर्दिष्ट करता है कि ब्राउज़र को अद्यतन पृष्ठ के लिए कितनी जल्दी पूछना चाहिए। आप कुछ सेकंड में समय निर्दिष्ट कर सकते हैं जिसके बाद एक पृष्ठ ताज़ा किया जाएगा। |
13 | Retry-After इस हेडर का उपयोग क्लाइंट को बताने के लिए 503 (सेवा अनुपलब्ध) प्रतिक्रिया के साथ संयोजन के रूप में किया जा सकता है कि वह कितनी जल्दी अपना अनुरोध दोहरा सकता है। |
14 | Set-Cookie यह शीर्ष लेख पृष्ठ से जुड़ा एक कुकी निर्दिष्ट करता है। |
HTTP रिस्पांस हैडर सेट करने के तरीके
निम्नलिखित तरीके हैं जो आपके सर्वलेट प्रोग्राम में HTTP प्रतिक्रिया हेडर सेट करने के लिए उपयोग किए जा सकते हैं। ये तरीके HttpServletResponse ऑब्जेक्ट के साथ उपलब्ध हैं ।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | String encodeRedirectURL(String url) SendRedirect विधि में उपयोग के लिए निर्दिष्ट URL को एन्कोड करता है या, यदि एन्कोडिंग की आवश्यकता नहीं है, तो URL को अपरिवर्तित लौटाता है। |
2 | String encodeURL(String url) इसमें सत्र आईडी शामिल करके निर्दिष्ट URL को एनकोड करता है, या, यदि एन्कोडिंग की आवश्यकता नहीं है, तो URL अपरिवर्तित लौटाता है। |
3 | boolean containsHeader(String name) एक बूलियन को इंगित करता है कि नामांकित प्रतिक्रिया शीर्ष लेख पहले ही सेट किया गया है। |
4 | boolean isCommitted() यदि प्रतिक्रिया हुई है तो यह इंगित करते हुए एक बूलियन लौटाता है। |
5 | void addCookie(Cookie cookie) निर्दिष्ट कुकी को प्रतिक्रिया में जोड़ता है। |
6 | void addDateHeader(String name, long date) दिए गए नाम और दिनांक-मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
7 | void addHeader(String name, String value) दिए गए नाम और मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
8 | void addIntHeader(String name, int value) दिए गए नाम और पूर्णांक मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
9 | void flushBuffer() क्लाइंट को लिखी जाने वाली बफर की किसी भी सामग्री को मजबूर करता है। |
10 | void reset() बफर में मौजूद किसी भी डेटा को क्लियर करने के साथ ही स्टेटस कोड और हेडर। |
1 1 | void resetBuffer() हेडर या स्थिति कोड को साफ़ किए बिना प्रतिक्रिया में अंतर्निहित बफर की सामग्री को साफ करता है। |
12 | void sendError(int sc) निर्दिष्ट स्थिति कोड का उपयोग करके ग्राहक को एक त्रुटि प्रतिक्रिया भेजता है और बफर को साफ़ करता है। |
13 | void sendError(int sc, String msg) निर्दिष्ट स्थिति का उपयोग करके क्लाइंट को एक त्रुटि प्रतिक्रिया भेजता है। |
14 | void sendRedirect(String location) निर्दिष्ट रीडायरेक्ट स्थान URL का उपयोग करके क्लाइंट को एक अस्थायी पुनर्निर्देशित प्रतिक्रिया भेजता है। |
15 | void setBufferSize(int size) प्रतिक्रिया के शरीर के लिए पसंदीदा बफर आकार सेट करता है। |
16 | void setCharacterEncoding(String charset) क्लाइंट को भेजे जा रहे रिस्पॉन्स के कैरेक्टर एन्कोडिंग (MIME चार्जसेट) को सेट करता है, उदाहरण के लिए, UTF-8 को। |
17 | void setContentLength(int len) प्रतिक्रिया में सामग्री बॉडी की लंबाई सेट करता है HTTP सर्वलेट्स में, यह विधि HTTP कंटेंट-लेंथ हेडर सेट करती है। |
18 | void setContentType(String type) ग्राहक को भेजी जा रही प्रतिक्रिया का सामग्री प्रकार सेट करता है, अगर प्रतिक्रिया अभी तक प्रतिबद्ध नहीं हुई है। |
19 | void setDateHeader(String name, long date) दिए गए नाम और दिनांक-मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है। |
20 | void setHeader(String name, String value) दिए गए नाम और मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है। |
21 | void setIntHeader(String name, int value) दिए गए नाम और पूर्णांक मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है |
22 | void setLocale(Locale loc) प्रतिक्रिया का स्थान निर्धारित करता है, अगर प्रतिक्रिया अभी तक प्रतिबद्ध नहीं हुई है। |
23 | void setStatus(int sc) इस प्रतिक्रिया के लिए स्थिति कोड सेट करता है |
HTTP हैडर रिस्पांस उदाहरण
आप पहले से ही setContentType () विधि को पिछले उदाहरणों में काम करते हुए देख चुके हैं और निम्नलिखित उदाहरण भी उसी विधि का उपयोग करेंगे, इसके अतिरिक्त हम उपयोग करेंगे setIntHeader() सेट करने की विधि Refresh हैडर।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class Refresh extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set refresh, autoload time as 5 seconds
response.setIntHeader("Refresh", 5);
// Set response content type
response.setContentType("text/html");
// Get current time
Calendar calendar = new GregorianCalendar();
String am_pm;
int hour = calendar.get(Calendar.HOUR);
int minute = calendar.get(Calendar.MINUTE);
int second = calendar.get(Calendar.SECOND);
if(calendar.get(Calendar.AM_PM) == 0)
am_pm = "AM";
else
am_pm = "PM";
String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
PrintWriter out = response.getWriter();
String title = "Auto Refresh Header Setting";
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" +
"<p>Current Time is: " + CT + "</p>\n"
);
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब ऊपर दिए गए सर्वलेट को कॉल करने पर निम्न 5 सेकंड के बाद वर्तमान प्रणाली समय प्रदर्शित होगा। बस सर्वलेट चलाएं और परिणाम देखने के लिए इंतजार करें -
Auto Refresh Header Setting
Current Time is: 9:44:50 PM
HTTP अनुरोध और HTTP प्रतिक्रिया संदेशों का प्रारूप समान है और इसमें निम्नलिखित संरचना होगी -
एक प्रारंभिक स्थिति लाइन + CRLF (कैरिज रिटर्न + लाइन फ़ीड यानी नई लाइन)
शून्य या अधिक हेडर लाइन + CRLF
एक खाली लाइन, यानी, एक CRLF
एक वैकल्पिक संदेश निकाय जैसे फ़ाइल, क्वेरी डेटा या क्वेरी आउटपुट।
उदाहरण के लिए, एक सर्वर प्रतिक्रिया हेडर निम्नानुसार दिखता है -
HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
(Blank Line)
<!doctype ...>
<html>
<head>...</head>
<body>
...
</body>
</html>
स्टेटस लाइन में HTTP वर्जन (उदाहरण में HTTP / 1.1), एक स्टेटस कोड (उदाहरण में 200) और स्टेटस कोड (उदाहरण में ओके) के अनुरूप एक बहुत छोटा संदेश होता है।
निम्नलिखित HTTP स्थिति कोड और संबंधित संदेशों की एक सूची है जो वेब सर्वर से वापस आ सकती है -
कोड | संदेश | विवरण |
---|---|---|
100 | जारी रखें | अनुरोध का केवल एक हिस्सा सर्वर द्वारा प्राप्त किया गया है, लेकिन जब तक इसे अस्वीकार नहीं किया जाता है, ग्राहक को अनुरोध के साथ जारी रखना चाहिए |
101 | स्विचिंग प्रोटोकॉल | सर्वर प्रोटोकॉल स्विच करता है। |
200 | ठीक | अनुरोध ठीक है |
201 | बनाया था | अनुरोध पूरा हो गया है, और एक नया संसाधन बनाया गया है |
202 | स्वीकार किए जाते हैं | अनुरोध प्रसंस्करण के लिए स्वीकार किया जाता है, लेकिन प्रसंस्करण पूरा नहीं होता है। |
203 | गैर-आधिकारिक जानकारी | |
204 | कोई सामग्री नहीं है | |
205 | सामग्री रीसेट करें | |
206 | आंशिक सामग्री | |
300 | कई विकल्प | एक लिंक सूची। उपयोगकर्ता एक लिंक का चयन कर सकता है और उस स्थान पर जा सकता है। अधिकतम पांच पते |
301 | स्थाई रूप से स्थानांतरित | अनुरोधित पृष्ठ नए url में चला गया है |
302 | मिल गया | अनुरोधित पृष्ठ अस्थायी रूप से एक नए url में चला गया है |
303 | अन्य देखें | अनुरोधित पृष्ठ एक अलग यूआरएल के तहत पाया जा सकता है |
304 | बदला हुआ नहीं | |
305 | प्रॉक्सी का उपयोग करें | |
306 | अप्रयुक्त | इस कोड का उपयोग पिछले संस्करण में किया गया था। यह अब उपयोग नहीं किया जाता है, लेकिन कोड आरक्षित है |
307 | अस्थायी पुनर्निर्देश | अनुरोधित पृष्ठ अस्थायी रूप से एक नए url में चला गया है। |
400 | खराब अनुरोध | सर्वर ने अनुरोध को नहीं समझा |
401 | अनधिकृत | अनुरोधित पृष्ठ को उपयोगकर्ता नाम और पासवर्ड की आवश्यकता है |
402 | भुगतान की आवश्यकता है | आप अभी तक इस कोड का उपयोग नहीं कर सकते हैं |
403 | मना किया हुआ | अनुरोधित पृष्ठ पर प्रवेश वर्जित है |
404 | नहीं मिला | सर्वर अनुरोधित पृष्ठ नहीं ढूँढ सकता। |
405 | विधि की अनुमति नहीं है | अनुरोध में निर्दिष्ट विधि की अनुमति नहीं है। |
406 | स्वीकार्य नहीं है | सर्वर केवल एक प्रतिक्रिया उत्पन्न कर सकता है जिसे क्लाइंट द्वारा स्वीकार नहीं किया जाता है। |
407 | प्रॉक्सी प्रमाणीकरण आवश्यक है | इस अनुरोध को पूरा करने से पहले आपको एक प्रॉक्सी सर्वर के साथ प्रमाणित करना होगा। |
408 | ब्रेक का अनुरोध | प्रतीक्षा करने के लिए तैयार किए गए सर्वर से अनुरोध में अधिक समय लगा। |
409 | टकराव | संघर्ष के कारण अनुरोध पूरा नहीं हो सका। |
410 | गया हुआ | अनुरोधित पृष्ठ अब उपलब्ध नहीं है। |
411 | लंबाई आवश्यक है | "सामग्री-लंबाई" को परिभाषित नहीं किया गया है। सर्वर इसके बिना अनुरोध को स्वीकार नहीं करेगा। |
412 | पूर्वधारणा विफल | अनुरोध में दी गई पूर्व शर्त सर्वर द्वारा झूठी का मूल्यांकन किया गया। |
413 | अनुरोध इकाई बहुत बड़ी है | सर्वर अनुरोध को स्वीकार नहीं करेगा, क्योंकि अनुरोध इकाई बहुत बड़ी है। |
414 | अनुरोध-यूआरएल बहुत लंबा है | सर्वर अनुरोध को स्वीकार नहीं करेगा, क्योंकि url बहुत लंबा है। तब होता है जब आप "पोस्ट" अनुरोध को एक लंबी क्वेरी जानकारी के साथ "पाने" के अनुरोध में परिवर्तित करते हैं। |
415 | असमर्थित मीडिया प्रकार | सर्वर अनुरोध को स्वीकार नहीं करेगा, क्योंकि मीडिया प्रकार समर्थित नहीं है। |
417 | उम्मीद फेल हो गई | |
500 | आंतरिक सर्वर त्रुटि | अनुरोध पूरा नहीं हुआ था। सर्वर एक अप्रत्याशित स्थिति से मिला। |
501 | कार्यान्वित नहीं | अनुरोध पूरा नहीं हुआ था। सर्वर ने आवश्यक कार्यक्षमता का समर्थन नहीं किया। |
502 | खराब गेटवे | अनुरोध पूरा नहीं हुआ था। सर्वर को अपस्ट्रीम सर्वर से एक अमान्य प्रतिक्रिया मिली। |
503 | सेवा उप्लब्ध् नहीं है | अनुरोध पूरा नहीं हुआ था। सर्वर अस्थायी रूप से ओवरलोडिंग या डाउन है। |
504 | गेटवे समय समाप्त | प्रवेश द्वार का समय समाप्त हो गया है। |
505 | HTTP संस्करण समर्थित नहीं है | सर्वर "http प्रोटोकॉल" संस्करण का समर्थन नहीं करता है। |
HTTP स्टेटस कोड सेट करने के तरीके
आपके सर्वलेट प्रोग्राम में HTTP स्टेटस कोड सेट करने के लिए निम्न विधियों का उपयोग किया जा सकता है। ये तरीके HttpServletResponse ऑब्जेक्ट के साथ उपलब्ध हैं ।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | public void setStatus ( int statusCode ) यह विधि एक मनमाना स्थिति कोड सेट करती है। सेटस्टैटस पद्धति एक तर्क के रूप में एक इंट (स्टेटस कोड) लेती है। आपकी प्रतिक्रिया को विशेष दर्जा कोड और एक दस्तावेज शामिल हैं, तो वास्तव में साथ सामग्री के किसी भी लौटने से पहले setStatus कॉल करने के लिए सुनिश्चित हो PrintWriter । |
2 | public void sendRedirect(String url) यह विधि नए दस्तावेज़ का URL देने वाले स्थान हेडर के साथ एक 302 प्रतिक्रिया उत्पन्न करती है |
3 | public void sendError(int code, String message) यह विधि एक छोटे संदेश के साथ एक स्थिति कोड (आमतौर पर 404) भेजता है जो स्वचालित रूप से HTML दस्तावेज़ के अंदर स्वरूपित होता है और क्लाइंट को भेजा जाता है। |
HTTP स्थिति कोड उदाहरण
निम्नलिखित वह उदाहरण है जो क्लाइंट ब्राउज़र में 407 त्रुटि कोड भेजेगा और ब्राउज़र आपको "आवश्यकता प्रमाणीकरण !!!" दिखाएगा। संदेश।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class showError extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set error code and reason.
response.sendError(407, "Need authentication!!!" );
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब उपरोक्त सर्वलेट को कॉल करने से निम्नलिखित परिणाम प्रदर्शित होंगे -
HTTP Status 407 - Need authentication!!!
type Status report
messageNeed authentication!!!
descriptionThe client must first authenticate itself with the proxy (Need authentication!!!).
Apache Tomcat/5.5.29
सर्वलेट फ़िल्टर जावा कक्षाएं हैं जिनका उपयोग निम्नलिखित उद्देश्यों के लिए सर्वलेट प्रोग्रामिंग में किया जा सकता है -
बैक एंड पर संसाधन तक पहुँचने से पहले क्लाइंट से अनुरोधों को रोकना।
क्लाइंट से वापस भेजे जाने से पहले सर्वर से प्रतिक्रियाओं में हेरफेर करने के लिए।
विनिर्देशों द्वारा सुझाए गए विभिन्न प्रकार के फ़िल्टर हैं -
- प्रमाणीकरण फ़िल्टर।
- डेटा संपीड़न फ़िल्टर।
- एन्क्रिप्शन फ़िल्टर।
- फ़िल्टर जो संसाधन पहुंच घटनाओं को ट्रिगर करते हैं।
- छवि रूपांतरण फ़िल्टर।
- लॉगिंग और ऑडिटिंग फिल्टर।
- MIME-TYPE चेन फ़िल्टर।
- टोकन छानना।
- एक्सएसएल / टी फिल्टर जो एक्सएमएल कंटेंट को ट्रांसफॉर्म करते हैं।
फ़िल्टर तैनाती डिस्क्रिप्टर फ़ाइल में तैनात हैं web.xml और फिर आपके आवेदन की तैनाती विवरणक में या तो सर्वलेट नाम या URL पैटर्न पर मैप करें।
जब वेब कंटेनर आपके वेब एप्लिकेशन को शुरू करता है, तो यह प्रत्येक फ़िल्टर का एक उदाहरण बनाता है जिसे आपने परिनियोजन वर्णनकर्ता में घोषित किया है। फ़िल्टर उस क्रम में निष्पादित होते हैं जो उन्हें परिनियोजन विवरणक में घोषित किया जाता है।
सर्वलेट फ़िल्टर के तरीके
एक फ़िल्टर बस एक जावा वर्ग है जो javax.servlet.Filter इंटरफ़ेस को लागू करता है। Javax.servlet.Filter इंटरफ़ेस तीन विधियों को परिभाषित करता है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | public void doFilter (ServletRequest, ServletResponse, FilterChain) यह विधि कंटेनर द्वारा हर बार एक रिक्वेस्ट / रिस्पॉन्स जोड़ी चेन के अंत में एक संसाधन के लिए क्लाइंट अनुरोध के कारण चेन से होकर गुजरती है। |
2 | public void init(FilterConfig filterConfig) इस विधि को वेब कंटेनर द्वारा एक फिल्टर को इंगित करने के लिए कहा जाता है जिसे इसे सेवा में रखा जा रहा है। |
3 | public void destroy() इस विधि को वेब कंटेनर द्वारा एक फिल्टर को इंगित करने के लिए कहा जाता है जो इसे सेवा से बाहर ले जा रहा है। |
सर्वलेट फ़िल्टर - उदाहरण
निम्नलिखित है सर्वलेट फ़िल्टर उदाहरण जो ग्राहकों के आईपी पते और वर्तमान तिथि समय को प्रिंट करेगा। यह उदाहरण आपको सर्वलेट फ़िल्टर की बुनियादी समझ देगा, लेकिन आप एक ही अवधारणा का उपयोग करके अधिक परिष्कृत फ़िल्टर अनुप्रयोग लिख सकते हैं -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Implements Filter class
public class LogFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
// Get init parameter
String testParam = config.getInitParameter("test-param");
//Print the init parameter
System.out.println("Test Param: " + testParam);
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws java.io.IOException, ServletException {
// Get the IP address of client machine.
String ipAddress = request.getRemoteAddr();
// Log the IP address and current timestamp.
System.out.println("IP "+ ipAddress + ", Time " + new Date().toString());
// Pass request back down the filter chain
chain.doFilter(request,response);
}
public void destroy( ) {
/* Called before the Filter instance is removed from service by the web container*/
}
}
संकलन LogFilter.java सामान्य तरीके से और अपनी कक्षा की फ़ाइल को <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / कक्षाओं में डालें
Web.xml में सर्वलेट फ़िल्टर मैपिंग
फ़िल्टर को परिभाषित किया जाता है और फिर URL या सर्वलेट में मैप किया जाता है, उसी तरह से जिसे Servlet परिभाषित किया गया है और फिर URL पैटर्न में मैप किया गया है। परिनियोजन डिस्क्रिप्टर फ़ाइल में फ़िल्टर टैग के लिए निम्न प्रविष्टि बनाएँweb.xml
<filter>
<filter-name>LogFilter</filter-name>
<filter-class>LogFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
उपरोक्त फ़िल्टर सभी सर्वलेट्स पर लागू होगा क्योंकि हमने निर्दिष्ट किया था /*हमारे विन्यास में। यदि आप केवल कुछ सर्वलेट्स पर फ़िल्टर लागू करना चाहते हैं, तो आप किसी विशेष सर्वलेट पथ को निर्दिष्ट कर सकते हैं।
अब किसी भी सर्वलेट को सामान्य तरीके से कॉल करने का प्रयास करें और आपको अपने वेब सर्वर लॉग में जनरेट लॉग दिखाई देगा। एक अलग फ़ाइल में लॉग इन करने के लिए आप Log4J लकड़हारे का उपयोग कर सकते हैं।
एकाधिक फ़िल्टर का उपयोग करना
आपका वेब एप्लिकेशन एक विशिष्ट उद्देश्य के साथ कई अलग-अलग फ़िल्टर परिभाषित कर सकता है। गौर कीजिए, आप दो फिल्टर ऑटेनफिल्टर और लॉगफिल्टर को परिभाषित करते हैं । बाकी प्रक्रिया ऊपर बताई गई है, इसके अलावा आपको नीचे बताए अनुसार एक अलग मैपिंग बनाने की आवश्यकता है -
<filter>
<filter-name>LogFilter</filter-name>
<filter-class>LogFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter>
<filter-name>AuthenFilter</filter-name>
<filter-class>AuthenFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>AuthenFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
फिल्टर आवेदन आदेश
Web.xml में फ़िल्टर-मैपिंग तत्वों का क्रम उस क्रम को निर्धारित करता है जिसमें वेब कंटेनर फ़िल्टर को सर्वलेट पर लागू करता है। फ़िल्टर के क्रम को उलटने के लिए, आपको बस web.xml फ़ाइल में फ़िल्टर-मैपिंग तत्वों को उल्टा करना होगा।
उदाहरण के लिए, उपरोक्त उदाहरण पहले LogFilter को लागू करेगा और फिर यह किसी भी सर्वलेट में AuthenFilter को लागू करेगा लेकिन निम्नलिखित उदाहरण के क्रम को उलट देगा -
<filter-mapping>
<filter-name>AuthenFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
जब एक सर्वलेट एक अपवाद फेंकता है, तो वेब कंटेनर कॉन्फ़िगरेशन को खोजता है web.xml थ्रो अपवाद प्रकार के साथ मैच के लिए अपवाद-प्रकार के तत्व का उपयोग करें।
आप का उपयोग करना होगा error-page कुछ के जवाब में सर्वलेट्स के आह्वान को निर्दिष्ट करने के लिए web.xml में तत्व exceptions या HTTP status codes।
web.xml कॉन्फ़िगरेशन
गौर कीजिए, आपके पास एक एररहैंडलर सर्वलेट है जिसे जब भी कोई परिभाषित अपवाद या त्रुटि कहा जाएगा। निम्नलिखित web.xml में बनाई गई प्रविष्टि होगी।
<!-- servlet definition -->
<servlet>
<servlet-name>ErrorHandler</servlet-name>
<servlet-class>ErrorHandler</servlet-class>
</servlet>
<!-- servlet mappings -->
<servlet-mapping>
<servlet-name>ErrorHandler</servlet-name>
<url-pattern>/ErrorHandler</url-pattern>
</servlet-mapping>
<!-- error-code related error pages -->
<error-page>
<error-code>404</error-code>
<location>/ErrorHandler</location>
</error-page>
<error-page>
<error-code>403</error-code>
<location>/ErrorHandler</location>
</error-page>
<!-- exception-type related error pages -->
<error-page>
<exception-type>
javax.servlet.ServletException
</exception-type >
<location>/ErrorHandler</location>
</error-page>
<error-page>
<exception-type>java.io.IOException</exception-type >
<location>/ErrorHandler</location>
</error-page>
यदि आप सभी अपवादों के लिए एक सामान्य त्रुटि हैंडलर चाहते हैं तो आपको हर अपवाद के लिए अलग त्रुटि-पृष्ठ तत्वों को परिभाषित करने के बजाय निम्नलिखित त्रुटि पृष्ठ को परिभाषित करना चाहिए -
<error-page>
<exception-type>java.lang.Throwable</exception-type >
<location>/ErrorHandler</location>
</error-page>
निम्न बिंदुओं के बारे में निम्नलिखित हैं।
सर्वलेट ErrorHandler को किसी भी अन्य सर्वलेट के रूप में सामान्य रूप से परिभाषित किया गया है और web.xml में कॉन्फ़िगर किया गया है।
यदि 404 (नहीं मिला) या 403 (निषिद्ध) स्थिति कोड के साथ कोई त्रुटि है, तो ErrorHandler सर्वलेट कहा जाएगा।
यदि वेब अनुप्रयोग ServletException या IOException को फेंकता है, तो वेब कंटेनर / ErrorHandler सर्वलेट को आमंत्रित करता है।
आप विभिन्न प्रकार की त्रुटियों या अपवादों को संभालने के लिए विभिन्न त्रुटि हैंडलर्स को परिभाषित कर सकते हैं। उपरोक्त उदाहरण बहुत अधिक सामान्य है और आशा है कि यह आपको मूल अवधारणा को समझाने के उद्देश्य से काम करेगा।
अनुरोध विशेषताएं - त्रुटियां / अपवाद
निम्नलिखित अनुरोध विशेषताओं की सूची है जो त्रुटि-हैंडलिंग सर्वलेट त्रुटि / अपवाद की प्रकृति का विश्लेषण करने के लिए उपयोग कर सकते हैं।
अनु क्रमांक। | विशेषता और विवरण |
---|---|
1 | javax.servlet.error.status_code यह विशेषता स्थिति कोड देती है जिसे java.lang.Integer डेटा प्रकार में संग्रहीत करने के बाद संग्रहीत और विश्लेषण किया जा सकता है। |
2 | javax.servlet.error.exception_type यह विशेषता अपवाद प्रकार के बारे में जानकारी देती है जिसे java.lang.Class डेटा प्रकार में संग्रहीत करने के बाद संग्रहीत और विश्लेषण किया जा सकता है। |
3 | javax.servlet.error.message यह विशेषता सूचना को सटीक त्रुटि संदेश देती है जिसे java.lang.String डेटा प्रकार में संग्रहीत करने के बाद संग्रहीत और विश्लेषण किया जा सकता है। |
4 | javax.servlet.error.request_uri यह विशेषता URL को सर्वलेट को कॉल करने के बारे में जानकारी देती है और इसे java.lang.Stang डेटा प्रकार में संग्रहीत करने के बाद संग्रहीत और विश्लेषण किया जा सकता है। |
5 | javax.servlet.error.exception यह विशेषता उठाए गए अपवाद के बारे में जानकारी देती है, जिसे संग्रहीत और विश्लेषण किया जा सकता है। |
6 | javax.servlet.error.servlet_name यह विशेषता सर्वलेट नाम देती है जिसे java.lang.String डेटा प्रकार में संग्रहीत करने के बाद संग्रहीत और विश्लेषण किया जा सकता है। |
त्रुटि हैंडलर सर्वलेट उदाहरण
यह उदाहरण आपको सर्वलेट में अपवाद हैंडलिंग की बुनियादी समझ देगा, लेकिन आप एक ही अवधारणा का उपयोग करके अधिक परिष्कृत फ़िल्टर अनुप्रयोग लिख सकते हैं -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class ErrorHandler extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Analyze the servlet exception
Throwable throwable = (Throwable)
request.getAttribute("javax.servlet.error.exception");
Integer statusCode = (Integer)
request.getAttribute("javax.servlet.error.status_code");
String servletName = (String)
request.getAttribute("javax.servlet.error.servlet_name");
if (servletName == null) {
servletName = "Unknown";
}
String requestUri = (String)
request.getAttribute("javax.servlet.error.request_uri");
if (requestUri == null) {
requestUri = "Unknown";
}
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Error/Exception Information";
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 (throwable == null && statusCode == null) {
out.println("<h2>Error information is missing</h2>");
out.println("Please return to the <a href=\"" +
response.encodeURL("http://localhost:8080/") +
"\">Home Page</a>.");
} else if (statusCode != null) {
out.println("The status code : " + statusCode);
} else {
out.println("<h2>Error information</h2>");
out.println("Servlet Name : " + servletName + "</br></br>");
out.println("Exception Type : " + throwable.getClass( ).getName( ) + "</br></br>");
out.println("The request URI: " + requestUri + "<br><br>");
out.println("The exception message: " + throwable.getMessage( ));
}
out.println("</body>");
out.println("</html>");
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
संकलन ErrorHandler.java सामान्य तरीके से और अपनी कक्षा की फ़ाइल अंदर डालें
आइए हम अपवादों को संभालने के लिए web.xml में निम्नलिखित कॉन्फ़िगरेशन जोड़ते हैं -
<servlet>
<servlet-name>ErrorHandler</servlet-name>
<servlet-class>ErrorHandler</servlet-class>
</servlet>
<!-- servlet mappings -->
<servlet-mapping>
<servlet-name>ErrorHandler</servlet-name>
<url-pattern>/ErrorHandler</url-pattern>
</servlet-mapping>
<error-page>
<error-code>404</error-code>
<location>/ErrorHandler</location>
</error-page>
<error-page>
<exception-type>java.lang.Throwable</exception-type >
<location>/ErrorHandler</location>
</error-page>
अब एक सर्वलेट का उपयोग करने की कोशिश करें जो किसी भी अपवाद को बढ़ाता है या गलत URL टाइप करता है, इससे वेब कंटेनर को कॉल करने के लिए ट्रिगर किया जाएगा ErrorHandlerसर्वलेट और क्रमादेशित एक उपयुक्त संदेश प्रदर्शित करें। उदाहरण के लिए, यदि आप एक गलत URL टाइप करते हैं तो यह निम्नलिखित परिणाम प्रदर्शित करेगा -
The status code : 404
उपरोक्त कोड कुछ वेब ब्राउज़रों के साथ काम नहीं कर सकता है। तो मोज़िला और सफारी के साथ प्रयास करें और यह काम करना चाहिए।
कुकीज़ पाठ फ़ाइलें क्लाइंट कंप्यूटर पर संग्रहीत होती हैं और उन्हें विभिन्न सूचना ट्रैकिंग उद्देश्य के लिए रखा जाता है। जावा सर्वलेट्स 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 फ़ाइल में उचित प्रविष्टि बनाएँ। अगर आपने पहले_नाम कुकी को "जॉन" के रूप में और अंतिम_नाम कुकी को "प्लेयर" के रूप में सेट किया है, तो 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
आप अपने कुकीज़ को Internet Explorer में मैन्युअल रूप से हटा सकते हैं। टूल मेनू पर प्रारंभ करें और इंटरनेट विकल्प चुनें। सभी कुकी हटाने के लिए, कुकीज़ हटाएं दबाएं।
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 प्राप्त करता है।
यह ट्यूटोरियल मानता है कि JDBC एप्लिकेशन कैसे काम करता है, इस पर आपकी समझ है। सर्वलेट के माध्यम से डेटाबेस एक्सेस के साथ शुरू करने से पहले, सुनिश्चित करें कि आपके पास डेटाबेस के साथ उचित JDBC पर्यावरण सेटअप है।
JDBC और इसके पर्यावरण सेटअप का उपयोग करके डेटाबेस तक पहुँचने के तरीके के बारे में अधिक विस्तार के लिए आप हमारे JDBC ट्यूटोरियल के माध्यम से जा सकते हैं ।
बुनियादी अवधारणा से शुरू करने के लिए, आइए हम एक सरल तालिका बनाते हैं और उस तालिका में कुछ रिकॉर्ड बनाते हैं -
तालिका बनाएं
बनाने के लिए Employees TEST डेटाबेस में तालिका, निम्न चरणों का उपयोग करें -
चरण 1
एक खोलो Command Prompt और स्थापना निर्देशिका में परिवर्तन निम्नानुसार है -
C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>
चरण 2
डेटाबेस में निम्नानुसार लॉगिन करें
C:\Program Files\MySQL\bin>mysql -u root -p
Enter password: ********
mysql>
चरण 3
तालिका बनाएं Employee में TEST डेटाबेस इस प्रकार है -
mysql> use TEST;
mysql> create table Employees (
id int not null,
age int not null,
first varchar (255),
last varchar (255)
);
Query OK, 0 rows affected (0.08 sec)
mysql>
डेटा रिकॉर्ड बनाएँ
अंत में आप कर्मचारी तालिका में कुछ रिकॉर्ड बनाते हैं -
mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
Query OK, 1 row affected (0.05 sec)
mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
Query OK, 1 row affected (0.00 sec)
mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
Query OK, 1 row affected (0.00 sec)
mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
Query OK, 1 row affected (0.00 sec)
mysql>
एक डेटाबेस तक पहुँचने
यहाँ एक उदाहरण है जो दिखाता है कि सर्वलेट का उपयोग करके TEST डेटाबेस तक कैसे पहुँचें।
// Loading required libraries
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.*;
public class DatabaseAccess extends HttpServlet{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL="jdbc:mysql://localhost/TEST";
// Database credentials
static final String USER = "root";
static final String PASS = "password";
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Database Result";
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");
try {
// Register JDBC driver
Class.forName("com.mysql.jdbc.Driver");
// Open a connection
Connection conn = DriverManager.getConnection(DB_URL, USER, PASS);
// Execute SQL query
Statement stmt = conn.createStatement();
String sql;
sql = "SELECT id, first, last, age FROM Employees";
ResultSet rs = stmt.executeQuery(sql);
// Extract data from result set
while(rs.next()){
//Retrieve by column name
int id = rs.getInt("id");
int age = rs.getInt("age");
String first = rs.getString("first");
String last = rs.getString("last");
//Display values
out.println("ID: " + id + "<br>");
out.println(", Age: " + age + "<br>");
out.println(", First: " + first + "<br>");
out.println(", Last: " + last + "<br>");
}
out.println("</body></html>");
// Clean-up environment
rs.close();
stmt.close();
conn.close();
} catch(SQLException se) {
//Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
//Handle errors for Class.forName
e.printStackTrace();
} finally {
//finally block used to close resources
try {
if(stmt!=null)
stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null)
conn.close();
} catch(SQLException se) {
se.printStackTrace();
} //end finally try
} //end try
}
}
अब हमें सर्वलेट के ऊपर संकलन करें और web.xml में निम्नलिखित प्रविष्टियाँ बनाएँ
....
<servlet>
<servlet-name>DatabaseAccess</servlet-name>
<servlet-class>DatabaseAccess</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DatabaseAccess</servlet-name>
<url-pattern>/DatabaseAccess</url-pattern>
</servlet-mapping>
....
अब URL http: // localhost: 8080 / DatabaseAccess का उपयोग करके इस सर्वलेट को कॉल करें, जो निम्नलिखित प्रतिक्रिया प्रदर्शित करेगा -
Database Result
ID: 100, Age: 18, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
उपयोगकर्ताओं को सर्वर पर फाइल अपलोड करने की अनुमति देने के लिए एक HTML फॉर्मेट टैग के साथ एक सर्वलेट का उपयोग किया जा सकता है। अपलोड की गई फ़ाइल एक टेक्स्ट फ़ाइल या छवि फ़ाइल या कोई दस्तावेज़ हो सकती है।
फ़ाइल अपलोड फॉर्म बनाना
नीचे दिया गया HTM कोड अपलोडर का रूप बनाता है। नीचे दिए गए महत्वपूर्ण बिंदु निम्नलिखित हैं -
फार्म method के लिए विशेषता निर्धारित की जानी चाहिए POST विधि और GET विधि का उपयोग नहीं किया जा सकता है
फार्म enctype के लिए विशेषता निर्धारित की जानी चाहिए multipart/form-data।
फार्म actionविशेषता को एक सर्वलेट फ़ाइल पर सेट किया जाना चाहिए जो बैकएंड सर्वर पर फ़ाइल अपलोडिंग को संभालती है। निम्नलिखित उदाहरण का उपयोग कर रहा हैUploadServlet फ़ाइल अपलोड करने के लिए सर्वलेट।
किसी एकल फ़ाइल को अपलोड करने के लिए आपको एकल <इनपुट ... /> टैग के साथ विशेषता प्रकार = "फ़ाइल" का उपयोग करना चाहिए। कई फ़ाइलों को अपलोड करने की अनुमति देने के लिए, नाम विशेषता के लिए विभिन्न मानों के साथ एक से अधिक इनपुट टैग शामिल करें। ब्राउज़र उनमें से प्रत्येक के साथ एक ब्राउज़ बटन को जोड़ता है।
<html>
<head>
<title>File Uploading Form</title>
</head>
<body>
<h3>File Upload:</h3>
Select a file to upload: <br />
<form action = "UploadServlet" method = "post" enctype = "multipart/form-data">
<input type = "file" name = "file" size = "50" />
<br />
<input type = "submit" value = "Upload File" />
</form>
</body>
</html>
यह निम्नलिखित परिणाम प्रदर्शित करेगा जो स्थानीय पीसी से एक फ़ाइल का चयन करने की अनुमति देगा और जब उपयोगकर्ता "अपलोड फ़ाइल" पर क्लिक करेगा, तो चयनित फिल्म के साथ फॉर्म जमा किया जाएगा -
File Upload:
Select a file to upload:
NOTE: This is just dummy form and would not work.
लेखन बैकेंड सर्वलेट
इसके बाद सर्वलेट है UploadServletजो अपलोड की गई फ़ाइल को स्वीकार करने और उसे निर्देशिका में संग्रहीत करने का ध्यान रखेगा <टॉमकैट-इंस्टॉलेशन-डायरेक्टरी> / वेबैप्स / डेटा। इस निर्देशिका का नाम बाहरी कॉन्फ़िगरेशन जैसे कि एक का उपयोग करके भी जोड़ा जा सकता हैcontext-param इस प्रकार से web.xml में तत्व -
<web-app>
....
<context-param>
<description>Location to store uploaded file</description>
<param-name>file-upload</param-name>
<param-value>
c:\apache-tomcat-5.5.29\webapps\data\
</param-value>
</context-param>
....
</web-app>
UploadServlet के लिए स्रोत कोड निम्नलिखित है जो एक समय में कई फ़ाइल अपलोडिंग को संभाल सकता है। आगे बढ़ने से पहले आपने यह सुनिश्चित कर लिया है कि -
निम्न उदाहरण FileUpload पर निर्भर करता है, इसलिए सुनिश्चित करें कि आपके पास नवीनतम संस्करण है commons-fileupload.x.x.jarअपने वर्गपथ में फ़ाइल करें। आप इससे डाउनलोड कर सकते हैंhttps://commons.apache.org/fileupload/।
FileUpload Commons IO पर निर्भर करता है, इसलिए सुनिश्चित करें कि आपके पास नवीनतम संस्करण है commons-io-x.x.jarअपने वर्गपथ में फ़ाइल करें। आप इससे डाउनलोड कर सकते हैंhttps://commons.apache.org/io/।
निम्नलिखित उदाहरण का परीक्षण करते समय, आपको एक फ़ाइल अपलोड करनी चाहिए, जिसका आकार अधिकतम से कम हो, अन्यथा फ़ाइल अपलोड नहीं की जाएगी।
सुनिश्चित करें कि आपने निर्देशिका c: \ temp और c: \ apache-tomcat8.0.28 \ webapps \ data को पहले से अच्छी तरह से बनाया है।
// Import required java libraries
import java.io.*;
import java.util.*;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.io.output.*;
public class UploadServlet extends HttpServlet {
private boolean isMultipart;
private String filePath;
private int maxFileSize = 50 * 1024;
private int maxMemSize = 4 * 1024;
private File file ;
public void init( ){
// Get the file location where it would be stored.
filePath = getServletContext().getInitParameter("file-upload");
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, java.io.IOException {
// Check that we have a file upload request
isMultipart = ServletFileUpload.isMultipartContent(request);
response.setContentType("text/html");
java.io.PrintWriter out = response.getWriter( );
if( !isMultipart ) {
out.println("<html>");
out.println("<head>");
out.println("<title>Servlet upload</title>");
out.println("</head>");
out.println("<body>");
out.println("<p>No file uploaded</p>");
out.println("</body>");
out.println("</html>");
return;
}
DiskFileItemFactory factory = new DiskFileItemFactory();
// maximum size that will be stored in memory
factory.setSizeThreshold(maxMemSize);
// Location to save data that is larger than maxMemSize.
factory.setRepository(new File("c:\\temp"));
// Create a new file upload handler
ServletFileUpload upload = new ServletFileUpload(factory);
// maximum file size to be uploaded.
upload.setSizeMax( maxFileSize );
try {
// Parse the request to get file items.
List fileItems = upload.parseRequest(request);
// Process the uploaded file items
Iterator i = fileItems.iterator();
out.println("<html>");
out.println("<head>");
out.println("<title>Servlet upload</title>");
out.println("</head>");
out.println("<body>");
while ( i.hasNext () ) {
FileItem fi = (FileItem)i.next();
if ( !fi.isFormField () ) {
// Get the uploaded file parameters
String fieldName = fi.getFieldName();
String fileName = fi.getName();
String contentType = fi.getContentType();
boolean isInMemory = fi.isInMemory();
long sizeInBytes = fi.getSize();
// Write the file
if( fileName.lastIndexOf("\\") >= 0 ) {
file = new File( filePath + fileName.substring( fileName.lastIndexOf("\\"))) ;
} else {
file = new File( filePath + fileName.substring(fileName.lastIndexOf("\\")+1)) ;
}
fi.write( file ) ;
out.println("Uploaded Filename: " + fileName + "<br>");
}
}
out.println("</body>");
out.println("</html>");
} catch(Exception ex) {
System.out.println(ex);
}
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, java.io.IOException {
throw new ServletException("GET method used with " +
getClass( ).getName( )+": POST method required.");
}
}
}
संकलन और रनिंग सर्वलेट
सर्वलेट UploadServlet के ऊपर संकलन करें और निम्नानुसार web.xml फ़ाइल में आवश्यक प्रविष्टि बनाएँ।
<servlet>
<servlet-name>UploadServlet</servlet-name>
<servlet-class>UploadServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>UploadServlet</servlet-name>
<url-pattern>/UploadServlet</url-pattern>
</servlet-mapping>
अब HTML फॉर्म का उपयोग करके फ़ाइलें अपलोड करने का प्रयास करें जो आपने ऊपर बनाई थी। जब आप http: // localhost: 8080 / UploadFile.htm की कोशिश करेंगे, तो यह निम्नलिखित परिणाम प्रदर्शित करेगा जो आपको अपने स्थानीय मशीन से किसी भी फ़ाइल को अपलोड करने में मदद करेगा।
File Upload:
Select a file to upload:
यदि आपकी सर्वलेट स्क्रिप्ट ठीक काम करती है, तो आपकी फ़ाइल c: \ Apache-tomcat8.0.28 \ webapps \ data \ directory में अपलोड होनी चाहिए।
सर्वलेट का उपयोग करने का सबसे महत्वपूर्ण लाभ यह है कि आप कोर जावा में उपलब्ध अधिकांश विधियों का उपयोग कर सकते हैं। यह ट्यूटोरियल आपको जावा प्रदान के माध्यम से ले जाएगाDate जो वर्ग में उपलब्ध है java.util पैकेज, यह वर्ग वर्तमान तिथि और समय को अलग करता है।
दिनांक वर्ग दो कंस्ट्रक्टर का समर्थन करता है। पहला निर्माता वर्तमान दिनांक और समय के साथ ऑब्जेक्ट को इनिशियलाइज़ करता है।
Date( )
निम्नलिखित निर्माणकर्ता एक तर्क को स्वीकार करता है जो आधी रात के बाद से समाप्त हो चुके मिलीसेकंड की संख्या के बराबर है, 1 जनवरी, 1970
Date(long millisec)
एक बार जब आपके पास दिनांक वस्तु उपलब्ध हो जाती है, तो आप तारीखों के साथ खेलने के लिए निम्नलिखित समर्थन विधियों में से कोई भी कॉल कर सकते हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | boolean after(Date date) यदि रिटर्न करने वाली दिनांक ऑब्जेक्ट में कोई दिनांक है जो बाद में दिनांक द्वारा निर्दिष्ट की गई तारीख से भिन्न है, तो सही है, अन्यथा, यह गलत है। |
2 | boolean before(Date date) यदि रिटर्न करने वाली दिनांक ऑब्जेक्ट में वह दिनांक है जो पहले से निर्दिष्ट दिनांक से भिन्न है, तो सही है, अन्यथा, यह गलत है। |
3 | Object clone( ) लागू दिनांक ऑब्जेक्ट को डुप्लिकेट करता है। |
4 | int compareTo(Date date) उस दिनांक के साथ आवर्ती वस्तु के मूल्य की तुलना करता है। मान बराबर होने पर 0 देता है। एक नकारात्मक मान लौटाता है यदि आह्वान करने वाली वस्तु पहले की तुलना में पुरानी हो। एक सकारात्मक मान लौटाता है यदि आह्वान करने वाली वस्तु बाद की तारीख में है। |
5 | int compareTo(Object obj) यदि ओबीजी वर्ग तिथि का है, तो तुलनात्मक रूप से (तिथि) के लिए परिचालन करता है। अन्यथा, यह एक ClassCastException फेंकता है। |
6 | boolean equals(Object date) अगर रिटर्न दिनांक ऑब्जेक्ट में एक ही समय और दिनांक के रूप में दिनांक द्वारा निर्दिष्ट है, अन्यथा, यह सही है, तो यह सही है। |
7 | long getTime( ) 1 जनवरी, 1970 के बाद से मिले मिलीसेकंड की संख्या लौटाता है। |
8 | int hashCode( ) वापस आने वाली वस्तु के लिए एक हैश कोड देता है। |
9 | void setTime(long time) समय और दिनांक को समय के अनुसार निर्दिष्ट करता है, जो 1 जनवरी, 1970 की मध्यरात्रि से मिलीसेकंड में बीता हुआ समय दर्शाता है। |
10 | String toString( ) लागू दिनांक ऑब्जेक्ट को एक स्ट्रिंग में परिवर्तित करता है और परिणाम देता है। |
वर्तमान तिथि और समय प्राप्त करना
जावा सर्वलेट में वर्तमान दिनांक और समय प्राप्त करना बहुत आसान है। आप वर्तमान तिथि और समय को निम्न प्रकार से प्रिंट करने के लिए () पद्धति के साथ एक साधारण दिनांक वस्तु का उपयोग कर सकते हैं -
// Import required java libraries
import java.io.*;
import java.util.Date;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class CurrentDate extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Display Current Date & Time";
Date date = new Date();
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\">" + date.toString() + "</h2>\n" +
"</body>
</html>"
);
}
}
अब हम सर्वलेट के ऊपर संकलित करें और web.xml में उपयुक्त प्रविष्टियाँ बनाएँ और फिर URL http: // localhost: 8080 / CurrentDate का उपयोग करके इस सर्वलेट को कॉल करें। इसका परिणाम निम्न होगा -
Display Current Date & Time
Mon Jun 21 21:46:49 GMT+04:00 2010
URL को रीफ़्रेश करने का प्रयास करें http: // localhost: 8080 / CurrentDate और जब भी आप रिफ्रेश होते हैं, तो आपको सेकंड में अंतर मिलेगा।
तारीख तुलना
जैसा कि मैंने ऊपर बताया है कि आप अपने सर्वलेट में उपलब्ध सभी जावा विधियों का उपयोग कर सकते हैं। मामले में आपको दो तिथियों की तुलना करने की आवश्यकता है, निम्नलिखित तरीके हैं -
आप दोनों वस्तुओं के लिए आधी रात, 1 जनवरी, 1970 से बीती हुई मिलीसेकंड की संख्या प्राप्त करने के लिए गेटटाइम () का उपयोग कर सकते हैं और फिर इन दोनों मूल्यों की तुलना कर सकते हैं।
आप पहले (), बाद (), और बराबर () तरीकों का उपयोग कर सकते हैं। क्योंकि महीने की 12 वीं 18 वीं से पहले आती है, उदाहरण के लिए, नई तिथि (99, 2, 12) .before (नई तिथि (99, 2, 18)) सही है।
आप तुलना () विधि का उपयोग कर सकते हैं, जिसे तुलनात्मक इंटरफ़ेस द्वारा परिभाषित किया गया है और तिथि द्वारा कार्यान्वित किया गया है।
SimpleDateFormat का उपयोग करते हुए दिनांक स्वरूपण
SimpleDateFormat स्थानीय रूप से तिथियों को प्रारूपित और पार्स करने के लिए एक ठोस वर्ग है। SimpleDateFormat आपको दिनांक-समय स्वरूपण के लिए किसी भी उपयोगकर्ता-परिभाषित पैटर्न को चुनकर शुरू करने की अनुमति देता है।
आइए हम उपरोक्त उदाहरण को संशोधित करें -
// Import required java libraries
import java.io.*;
import java.text.*;
import java.util.Date;
import javax.servlet.*;
import javax.servlet.http.*;
// Extend HttpServlet class
public class CurrentDate extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Display Current Date & Time";
Date dNow = new Date( );
SimpleDateFormat ft = new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz");
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\">" + ft.format(dNow) + "</h2>\n" +
"</body>
</html>"
);
}
}
एक बार फिर सर्वलेट के ऊपर संकलन करें और फिर URL http: // localhost: 8080 / CurrentDate का उपयोग करके इस सर्वलेट को कॉल करें। इसका परिणाम निम्न होगा -
Display Current Date & Time
Mon 2010.06.21 at 10:06:44 PM GMT+04:00
सरल DateFormat प्रारूप कोड
समय प्रारूप निर्दिष्ट करने के लिए एक समय पैटर्न स्ट्रिंग का उपयोग करें। इस पैटर्न में, सभी ASCII अक्षर पैटर्न अक्षरों के रूप में आरक्षित हैं, जिन्हें निम्नलिखित के रूप में परिभाषित किया गया है -
चरित्र | विवरण | उदाहरण |
---|---|---|
जी | युग का सूत्रधार | विज्ञापन |
y | चार अंकों में वर्ष | 2001 |
म | साल में महीना | जुलाई या ० July |
घ | महीने में दिन | 10 |
एच | AM / PM में घंटे (1 ~ 12) | 12 |
एच | दिन में घंटे (0 ~ 23) | 22 |
म | घंटे में मिनट | 30 |
रों | दूसरा मिनट में | 55 |
रों | मिलीसेकंड | 234 |
इ | सप्ताह में दिन | मंगलवार |
घ | वर्ष में दिन | 360 |
एफ | महीने में सप्ताह का दिन | 2 (जुलाई में दूसरा बुध) |
w | साल में सप्ताह | 40 |
डब्ल्यू | महीने में सप्ताह | 1 |
ए | AM / PM मार्कर | बजे |
क | दिन में घंटा (1 ~ 24) | 24 |
क | AM / PM में घंटे (0 ~ 11) | 10 |
जेड | समय क्षेत्र | पूर्व मानक समय |
' | पाठ के लिए बच | सीमान्तक |
" | एकल बोली | ` |
तारीख में हेरफेर करने के लिए लगातार उपलब्ध तरीकों की पूरी सूची के लिए, आप मानक जावा प्रलेखन का उल्लेख कर सकते हैं।
पृष्ठ पुनर्निर्देशन एक ऐसी तकनीक है जिसमें ग्राहक को अनुरोध के अलावा एक नए स्थान पर भेजा जाता है। पृष्ठ पुनर्निर्देशन आमतौर पर तब उपयोग किया जाता है जब कोई दस्तावेज़ किसी नए स्थान पर जाता है या लोड संतुलन के कारण हो सकता है।
किसी अन्य पृष्ठ पर अनुरोध को पुनर्निर्देशित करने का सबसे सरल तरीका विधि का उपयोग करना है sendRedirect()प्रतिक्रिया वस्तु के। निम्नलिखित इस विधि के हस्ताक्षर हैं -
public void HttpServletResponse.sendRedirect(String location)
throws IOException
यह विधि स्थिति कोड और नए पृष्ठ स्थान के साथ ब्राउज़र को प्रतिक्रिया वापस भेजती है। आप एक ही प्राप्त करने के लिए सेटस्टैटस () और सेटहेडर () विधियों का एक साथ उपयोग कर सकते हैं -
....
String site = "http://www.newpage.com" ;
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site);
....
उदाहरण
यह उदाहरण दिखाता है कि कैसे एक सर्वलेट किसी अन्य स्थान पर पृष्ठ पुनर्निर्देशन करता है -
import java.io.*;
import java.sql.Date;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class PageRedirect extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
// New location to be redirected
String site = new String("http://www.photofuntoos.com");
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site);
}
}
अब हमें सर्वलेट के ऊपर संकलन करें और web.xml में निम्नलिखित प्रविष्टियाँ बनाएँ
....
<servlet>
<servlet-name>PageRedirect</servlet-name>
<servlet-class>PageRedirect</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>PageRedirect</servlet-name>
<url-pattern>/PageRedirect</url-pattern>
</servlet-mapping>
....
अब URL http: // localhost: 8080 / PageRedirect का उपयोग करके इस सर्वलेट को कॉल करें। यह आपको http://www.photofuntoos.com URL पर रीडायरेक्ट करेगा।
एक वेब पेज के लिए काउंटर मारो
कई बार आपको अपनी वेबसाइट के किसी विशेष पृष्ठ पर कुल हिट्स जानने में रुचि होगी। सर्वलेट का उपयोग करके इन हिट्स को गिनना बहुत सरल है क्योंकि एक सर्वलेट का जीवन चक्र उस कंटेनर द्वारा नियंत्रित होता है जिसमें यह चलता है।
निम्नलिखित सरल चरण हिट काउंटर को लागू करने के लिए कदम उठाए जा रहे हैं जो सर्वलेट लाइफ साइकिल पर आधारित है -
एक वैश्विक वैरिएबल init () विधि को प्रारंभ करें।
हर बार या तो doGet () या doPost () विधि को ग्लोबल वैरिएबल कहा जाता है।
यदि आवश्यक हो, तो आप नष्ट () विधि में वैश्विक चर के मूल्य को संग्रहीत करने के लिए एक डेटाबेस तालिका का उपयोग कर सकते हैं। इस मान को इनिट () विधि के अंदर पढ़ा जा सकता है जब अगली बार सर्वलेट को प्रारंभ किया जाएगा। यह कदम वैकल्पिक है।
यदि आप केवल अनूठे पेज हिट्स को एक सत्र में गिनना चाहते हैं, तो आप उस सत्र में पहले से ही हिट हो चुके हैं, तो यह जांचने के लिए आप नेन () विधि का उपयोग कर सकते हैं। यह कदम वैकल्पिक है।
आप अपनी वेब साइट पर कुल हिट दिखाने के लिए वैश्विक काउंटर का मान प्रदर्शित कर सकते हैं। यह कदम भी वैकल्पिक है।
यहां मैं मान रहा हूं कि वेब कंटेनर को फिर से शुरू नहीं किया जाएगा। यदि इसे पुनः आरंभ या नष्ट किया गया सर्वलेट है, तो हिट काउंटर रीसेट हो जाएगा।
उदाहरण
यह उदाहरण दिखाता है कि एक साधारण पृष्ठ हिट काउंटर को कैसे लागू किया जाए -
import java.io.*;
import java.sql.Date;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class PageHitCounter extends HttpServlet {
private int hitCount;
public void init() {
// Reset hit counter.
hitCount = 0;
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
// This method executes whenever the servlet is hit
// increment hitCount
hitCount++;
PrintWriter out = response.getWriter();
String title = "Total Number of Hits";
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\">" + hitCount + "</h2>\n" +
"</body>
</html>"
);
}
public void destroy() {
// This is optional step but if you like you
// can write hitCount value in your database.
}
}
अब हमें सर्वलेट के ऊपर संकलन करें और web.xml में निम्नलिखित प्रविष्टियाँ बनाएँ
<servlet>
<servlet-name>PageHitCounter</servlet-name>
<servlet-class>PageHitCounter</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>PageHitCounter</servlet-name>
<url-pattern>/PageHitCounter</url-pattern>
</servlet-mapping>
....
अब URL http: // localhost: 8080 / PageHitCounter का उपयोग करके इस सर्वलेट को कॉल करें। यह इस पृष्ठ के ताज़ा होने पर हर बार एक-एक करके काउंटर बढ़ाता जाएगा और यह निम्नलिखित परिणाम प्रदर्शित करेगा -
Total Number of Hits
6
Hit Counter for a Website:
कई बार आपको अपनी पूरी वेबसाइट पर कुल हिट्स जानने में दिलचस्पी होगी। यह सर्वलेट में भी बहुत सरल है और हम इसे फ़िल्टर का उपयोग करके प्राप्त कर सकते हैं।
निम्नलिखित एक सरल वेबसाइट हिट काउंटर को लागू करने के लिए कदम उठाए जा रहे हैं जो कि फिल्टर लाइफ साइकिल पर आधारित है -
एक फिल्टर के एक वैश्विक चर init () विधि को प्रारंभ करें।
हर बार doFilter विधि को वैश्विक चर बढ़ाएँ।
यदि आवश्यक हो, तो आप फ़िल्टर की विधि को नष्ट करने () में वैश्विक चर के मूल्य को संग्रहीत करने के लिए एक डेटाबेस तालिका का उपयोग कर सकते हैं। इस मान को इनिट () विधि के अंदर पढ़ा जा सकता है, जब अगली बार फ़िल्टर प्रारंभ किया जाएगा। यह कदम वैकल्पिक है।
यहां मैं मान रहा हूं कि वेब कंटेनर को फिर से शुरू नहीं किया जाएगा। यदि इसे पुनः आरंभ या नष्ट किया गया सर्वलेट है, तो हिट काउंटर रीसेट हो जाएगा।
उदाहरण
यह उदाहरण दिखाता है कि एक साधारण वेबसाइट हिट काउंटर को कैसे लागू किया जाए -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class SiteHitCounter implements Filter {
private int hitCount;
public void init(FilterConfig config) throws ServletException {
// Reset hit counter.
hitCount = 0;
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws java.io.IOException, ServletException {
// increase counter by one
hitCount++;
// Print the counter.
System.out.println("Site visits count :"+ hitCount );
// Pass request back down the filter chain
chain.doFilter(request,response);
}
public void destroy() {
// This is optional step but if you like you
// can write hitCount value in your database.
}
}
अब हम उपरोक्त सर्वलेट को संकलित करते हैं और web.xml में निम्नलिखित प्रविष्टियाँ बनाते हैं
....
<filter>
<filter-name>SiteHitCounter</filter-name>
<filter-class>SiteHitCounter</filter-class>
</filter>
<filter-mapping>
<filter-name>SiteHitCounter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
....
अब URL http: // localhost: 8080 / जैसे किसी भी URL को कॉल करें। इससे किसी भी पृष्ठ के हिट होने पर हर बार काउंटर बढ़ेगा और यह लॉग में निम्न संदेश प्रदर्शित करेगा -
Site visits count : 1
Site visits count : 2
Site visits count : 3
Site visits count : 4
Site visits count : 5
..................
एक वेबपेज पर विचार करें जो लाइव गेम स्कोर या स्टॉक मार्केट स्थिति या मुद्रा विनिमय राशन प्रदर्शित कर रहा है। ऐसे सभी प्रकार के पृष्ठों के लिए, आपको अपने ब्राउज़र के साथ ताज़ा या पुनः लोड बटन का उपयोग करके अपने वेब पेज को नियमित रूप से ताज़ा करना होगा।
जावा सर्वलेट आपको एक तंत्र प्रदान करके इस काम को आसान बनाता है जहां आप एक वेबपेज इस तरह से बना सकते हैं कि यह दिए गए अंतराल के बाद स्वचालित रूप से ताज़ा हो जाएगा।
वेब पेज को रीफ्रेश करने का सबसे सरल तरीका विधि का उपयोग करना है setIntHeader()प्रतिक्रिया वस्तु के। निम्नलिखित इस विधि के हस्ताक्षर हैं -
public void setIntHeader(String header, int headerValue)
यह विधि ब्राउज़र को एक पूर्णांक मान के साथ "रीफ़्रेश" वापस भेजती है जो सेकंड में समय अंतराल को इंगित करता है।
ऑटो पेज ताज़ा उदाहरण
यह उदाहरण दिखाता है कि एक सर्वलेट ऑटो पेज रिफ्रेश का उपयोग कैसे करता है setIntHeader() सेट करने की विधि Refresh हैडर।
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class Refresh extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set refresh, autoload time as 5 seconds
response.setIntHeader("Refresh", 5);
// Set response content type
response.setContentType("text/html");
// Get current time
Calendar calendar = new GregorianCalendar();
String am_pm;
int hour = calendar.get(Calendar.HOUR);
int minute = calendar.get(Calendar.MINUTE);
int second = calendar.get(Calendar.SECOND);
if(calendar.get(Calendar.AM_PM) == 0)
am_pm = "AM";
else
am_pm = "PM";
String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
PrintWriter out = response.getWriter();
String title = "Auto Page Refresh using Servlet";
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" +
"<p>Current Time is: " + CT + "</p>\n"
);
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
अब हम उपरोक्त सर्वलेट को संकलित करते हैं और web.xml में निम्नलिखित प्रविष्टियाँ बनाते हैं
....
<servlet>
<servlet-name>Refresh</servlet-name>
<servlet-class>Refresh</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Refresh</servlet-name>
<url-pattern>/Refresh</url-pattern>
</servlet-mapping>
....
अब इस सर्वलेट को URL http: // localhost: 8080 / Refresh का उपयोग करके कॉल करें, जो वर्तमान सिस्टम समय को हर 5 सेकंड के बाद निम्नानुसार प्रदर्शित करेगा। बस सर्वलेट चलाएं और परिणाम देखने के लिए इंतजार करें -
Auto Page Refresh using Servlet
Current Time is: 9:44:50 PM
अपने सर्वलेट का उपयोग करके एक ईमेल भेजने के लिए पर्याप्त सरल है लेकिन आपके पास शुरू करने के लिए होना चाहिए JavaMail API तथा Java Activation Framework (JAF) आपकी मशीन पर स्थापित है।
आप जावा के मानक वेबसाइट से जावामैल (संस्करण 1.2) का नवीनतम संस्करण डाउनलोड कर सकते हैं ।
आप जावा की मानक वेबसाइट से जेएएफ (संस्करण 1.1.1) का नवीनतम संस्करण डाउनलोड कर सकते हैं ।
इन फ़ाइलों को डाउनलोड करें और अनज़िप करें, नए बनाए गए शीर्ष स्तर निर्देशिकाओं में आपको दोनों अनुप्रयोगों के लिए कई जार फाइलें मिलेंगी। आपको जोड़ने की आवश्यकता हैmail.jar तथा activation.jar आपके CLASSPATH में फ़ाइलें।
एक सरल ईमेल भेजें
आपकी मशीन से एक सरल ईमेल भेजने के लिए यहां एक उदाहरण दिया गया है। यहाँ यह माना जाता है कि आपकेlocalhostइंटरनेट से जुड़ा है और ईमेल भेजने के लिए पर्याप्त सक्षम है। एक ही समय सुनिश्चित करें कि जावा ईमेल एपीआई पैकेज और जेएएफ पैकेज से सभी जार फाइलें CLASSPATH में उपलब्ध हैं।
// File Name SendEmail.java
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;
public class SendEmail extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
// Assuming you are sending email from localhost
String host = "localhost";
// Get system properties
Properties properties = System.getProperties();
// Setup mail server
properties.setProperty("mail.smtp.host", host);
// Get the default Session object.
Session session = Session.getDefaultInstance(properties);
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
try {
// Create a default MimeMessage object.
MimeMessage message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
// Set Subject: header field
message.setSubject("This is the Subject Line!");
// Now set the actual message
message.setText("This is actual message");
// Send message
Transport.send(message);
String title = "Send Email";
String res = "Sent message successfully....";
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" +
"<p align = \"center\">" + res + "</p>\n" +
"</body>
</html>"
);
} catch (MessagingException mex) {
mex.printStackTrace();
}
}
}
अब हम उपरोक्त सर्वलेट को संकलित करते हैं और web.xml में निम्नलिखित प्रविष्टियाँ बनाते हैं
....
<servlet>
<servlet-name>SendEmail</servlet-name>
<servlet-class>SendEmail</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SendEmail</servlet-name>
<url-pattern>/SendEmail</url-pattern>
</servlet-mapping>
....
अब इस सर्वलेट को URL http: // localhost: 8080 / SendEmail का उपयोग करके कॉल करें, जो दिए गए ईमेल आईडी [email protected] पर एक ईमेल भेजेगा और निम्नलिखित प्रतिक्रिया प्रदर्शित करेगा -
Send Email
Sent message successfully....
यदि आप कई प्राप्तकर्ताओं को एक ईमेल भेजना चाहते हैं तो निम्नलिखित तरीकों का उपयोग कई ईमेल आईडी को निर्दिष्ट करने के लिए किया जाएगा -
void addRecipients(Message.RecipientType type, Address[] addresses)
throws MessagingException
यहाँ मापदंडों का वर्णन है -
type- यह TO, CC या BCC पर सेट किया जाएगा। यहाँ CC कार्बन कॉपी का प्रतिनिधित्व करता है और BCC ब्लैक कार्बन कॉपी का प्रतिनिधित्व करता है। उदाहरण संदेश। RecipientType.TO
addresses- यह ईमेल आईडी का एरे है। आपको ईमेल आईडी निर्दिष्ट करते समय InternetAddress () विधि का उपयोग करने की आवश्यकता होगी।
एक HTML ईमेल भेजें
अपनी मशीन से HTML ईमेल भेजने के लिए यहां एक उदाहरण दिया गया है। यहाँ यह माना जाता है कि आपकेlocalhostइंटरनेट से जुड़ा है और ईमेल भेजने के लिए पर्याप्त सक्षम है। उसी समय, सुनिश्चित करें कि जावा ईमेल एपीआई पैकेज और जेएएफ पैकेज से सभी जार फाइलें CLASSPATH में उपलब्ध हैं।
यह उदाहरण पिछले एक के समान है, सिवाय इसके कि हम सामग्री सेट करने के लिए सेटकंटेंट () विधि का उपयोग कर रहे हैं जिसका दूसरा तर्क "पाठ / एचटीएमएल" है यह निर्दिष्ट करने के लिए कि HTML सामग्री संदेश में शामिल है।
इस उदाहरण का उपयोग करके, आप अपनी पसंद के अनुसार HTML सामग्री भेज सकते हैं।
// File Name SendEmail.java
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;
public class SendEmail extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
// Assuming you are sending email from localhost
String host = "localhost";
// Get system properties
Properties properties = System.getProperties();
// Setup mail server
properties.setProperty("mail.smtp.host", host);
// Get the default Session object.
Session session = Session.getDefaultInstance(properties);
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
try {
// Create a default MimeMessage object.
MimeMessage message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
// Set Subject: header field
message.setSubject("This is the Subject Line!");
// Send the actual HTML message, as big as you like
message.setContent("<h1>This is actual message</h1>", "text/html" );
// Send message
Transport.send(message);
String title = "Send Email";
String res = "Sent message successfully....";
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" +
"<p align = \"center\">" + res + "</p>\n" +
"</body>
</html>"
);
} catch (MessagingException mex) {
mex.printStackTrace();
}
}
}
दिए गए ईमेल आईडी पर HTML संदेश भेजने के लिए उपरोक्त सर्वलेट को संकलित करें और चलाएं।
ईमेल में अटैचमेंट भेजें
अपनी मशीन से अनुलग्नक के साथ एक ईमेल भेजने के लिए यहां एक उदाहरण दिया गया है। यहाँ यह माना जाता है कि आपकेlocalhost इंटरनेट से जुड़ा है और ईमेल भेजने के लिए पर्याप्त सक्षम है।
// File Name SendEmail.java
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;
public class SendEmail extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
// Assuming you are sending email from localhost
String host = "localhost";
// Get system properties
Properties properties = System.getProperties();
// Setup mail server
properties.setProperty("mail.smtp.host", host);
// Get the default Session object.
Session session = Session.getDefaultInstance(properties);
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
try {
// Create a default MimeMessage object.
MimeMessage message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
// Set Subject: header field
message.setSubject("This is the Subject Line!");
// Create the message part
BodyPart messageBodyPart = new MimeBodyPart();
// Fill the message
messageBodyPart.setText("This is message body");
// Create a multipar message
Multipart multipart = new MimeMultipart();
// Set text message part
multipart.addBodyPart(messageBodyPart);
// Part two is attachment
messageBodyPart = new MimeBodyPart();
String filename = "file.txt";
DataSource source = new FileDataSource(filename);
messageBodyPart.setDataHandler(new DataHandler(source));
messageBodyPart.setFileName(filename);
multipart.addBodyPart(messageBodyPart);
// Send the complete message parts
message.setContent(multipart );
// Send message
Transport.send(message);
String title = "Send Email";
String res = "Sent message successfully....";
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" +
"<p align = \"center\">" + res + "</p>\n" +
"</body>
</html>"
);
} catch (MessagingException mex) {
mex.printStackTrace();
}
}
}
किसी ईमेल आईडी पर संदेश के साथ संलग्नक के रूप में फ़ाइल भेजने के लिए सर्वलेट के ऊपर संकलन करें और चलाएं।
उपयोगकर्ता प्रमाणीकरण भाग
यदि प्रमाणीकरण उद्देश्य के लिए ईमेल सर्वर पर उपयोगकर्ता आईडी और पासवर्ड प्रदान करना आवश्यक है तो आप इन गुणों को निम्नानुसार सेट कर सकते हैं -
props.setProperty("mail.user", "myuser");
props.setProperty("mail.password", "mypwd");
शेष ईमेल भेजने की व्यवस्था ऊपर बताई गई है।
WEB-INF उपनिर्देशिका में शामिल वेब एप्लिकेशन संरचना सभी जावा वेब अनुप्रयोगों के लिए मानक है और सर्वलेट एपीआई विनिर्देश द्वारा निर्दिष्ट है। एक उच्च स्तरीय निर्देशिका myapp का नाम दिया। यहाँ इस निर्देशिका संरचना की तरह दिखता है -
/myapp
/images
/WEB-INF
/classes
/lib
WEB-INF उपनिर्देशिका में web.xml नाम के एप्लिकेशन की तैनाती विवरणक शामिल है। सभी HTML फ़ाइलों को शीर्ष-स्तरीय निर्देशिका में रखा जाना चाहिए जो कि myapp है । व्यवस्थापक उपयोगकर्ता के लिए, आपको मूल निर्देशिका के रूप में ROOT निर्देशिका मिलेगी।
पैकेज में सर्वलेट बनाना
WEB-INF / classes डायरेक्टरी में सभी सर्वलेट क्लासेस और अन्य क्लास फाइल्स शामिल हैं, एक संरचना में जो उनके पैकेज के नाम से मेल खाती है। उदाहरण के लिए, यदि आपके पास पूरी तरह से योग्य वर्ग का नाम हैcom.myorg.MyServlet, तो यह सर्वलेट क्लास निम्नलिखित निर्देशिका में स्थित होना चाहिए -
/myapp/WEB-INF/classes/com/myorg/MyServlet.class
पैकेज नाम com.myorg के साथ MyServlet वर्ग बनाने के लिए निम्नलिखित उदाहरण है
// Name your package
package com.myorg;
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class MyServlet extends HttpServlet {
private String message;
public void init() throws ServletException {
// Do required initialization
message = "Hello World";
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
// Actual logic goes here.
PrintWriter out = response.getWriter();
out.println("<h1>" + message + "</h1>");
}
public void destroy() {
// do nothing.
}
}
संकुल में संकलन सर्वलेट्स
पैकेज में उपलब्ध वर्ग को संकलित करने के लिए कुछ अलग नहीं है। सबसे सरल तरीका यह है कि अपनी जावा फ़ाइल को पूरी तरह से योग्य पथ पर रखें, जैसा कि ऊपर वर्णित वर्ग com.myorg में रखा जाएगा। आपको CLASSPATH में इस निर्देशिका को जोड़ना होगा।
मान लें कि आपका वातावरण ठीक से सेटअप है, तो अंदर जाएं <Tomcat-installationdirectory>/ webapps / ROOT / WEB-INF / कक्षाएं निर्देशिका और MyServlet.java को निम्नानुसार संकलित करें
$ javac MyServlet.java
यदि सर्वलेट किसी अन्य लाइब्रेरी पर निर्भर करता है, तो आपको उन JAR फ़ाइलों को अपने CLASSPATH पर भी शामिल करना होगा। मैंने केवल सर्वलेट-एपी.जर जार फाइल को शामिल किया है क्योंकि मैं हैलो वर्ल्ड कार्यक्रम में किसी अन्य पुस्तकालय का उपयोग नहीं कर रहा हूं।
यह कमांड लाइन बिल्ट-इन जेवैक कंपाइलर का उपयोग करता है जो सन माइक्रोसिस्टम्स जावा सॉफ्टवेयर डेवलपमेंट किट (JDK) के साथ आता है। इस आदेश को ठीक से काम करने के लिए, आपको जावा एसडीके के स्थान को शामिल करना होगा जिसे आप पाथ पर्यावरण चर में उपयोग कर रहे हैं।
यदि सब कुछ ठीक हो जाता है, तो ऊपर संकलन का उत्पादन होगा MyServlet.classउसी निर्देशिका में फ़ाइल। अगला खंड बताता है कि उत्पादन में एक संकलित सर्वलेट कैसे तैनात किया जाएगा।
पैकेज्ड सर्वलेट तैनाती
डिफ़ॉल्ट रूप से, एक सर्वलेट एप्लिकेशन पथ पर स्थित है <Tomcat-setupdirectory> / webapps / ROOT और वर्ग फ़ाइल <Tomcat-installationdirectory> / webapp / ROOT / WEB-INF / कक्षाओं में निवास करेगा।
यदि आपके पास पूरी तरह से योग्य वर्ग का नाम है com.myorg.MyServlet, तो यह सर्वलेट क्लास WEB-INF / classes / com / myorg / MyServlet.class में स्थित होना चाहिए और आपको निम्नलिखित प्रविष्टियाँ बनाने की आवश्यकता होगी web.xml <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / में स्थित फ़ाइल
<servlet>
<servlet-name>MyServlet</servlet-name>
<servlet-class>com.myorg.MyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>MyServlet</servlet-name>
<url-pattern>/MyServlet</url-pattern>
</servlet-mapping>
उपरोक्त प्रविष्टियाँ <web-app> ... </ web-app> टैग के लिए web.xml फ़ाइल में उपलब्ध हैं। इस तालिका में पहले से ही उपलब्ध विभिन्न प्रविष्टियाँ हो सकती हैं, लेकिन कोई बात नहीं।
आप लगभग पूर्ण हो चुके हैं, अब हम टॉमकैट सर्वर को <Tomcat-installationdirectory> \ bin \ स्टार्टअप.bat (विंडोज़ पर) या <Tomcat-setupdirectory> /bin/startup.sh (लिनक्स / सोलारिस आदि) और अंत में टाइप का उपयोग करके शुरू करते हैं। http://localhost:8080/MyServletब्राउज़र के एड्रेस बॉक्स में। यदि सब कुछ ठीक रहा, तो आपको निम्नलिखित परिणाम प्राप्त होंगे -
Hello World
सर्वलेट्स को टेस्ट / डीबग करना हमेशा मुश्किल होता है। सर्वलेट में क्लाइंट / सर्वर इंटरैक्शन की एक बड़ी मात्रा शामिल होती है, जिससे त्रुटियों की संभावना होती है लेकिन पुन: पेश करने में मुश्किल होती है।
यहां कुछ संकेत और सुझाव दिए गए हैं जो आपकी डीबगिंग में आपकी सहायता कर सकते हैं।
Println ()
System.out.println () कोड के एक निश्चित टुकड़े को निष्पादित किया जा रहा है या नहीं, यह जांचने के लिए एक मार्कर के रूप में उपयोग करना आसान है। हम चर मानों को भी प्रिंट कर सकते हैं। इसके अतिरिक्त -
चूंकि सिस्टम ऑब्जेक्ट कोर जावा ऑब्जेक्ट का हिस्सा है, इसलिए इसे किसी भी अतिरिक्त कक्षाओं को स्थापित करने की आवश्यकता के बिना हर जगह उपयोग किया जा सकता है। इसमें सर्वलेट्स, जेएसपी, आरएमआई, ईजेबी, साधारण बीन्स और कक्षाएं, और स्टैंडअलोन एप्लिकेशन शामिल हैं।
ब्रेकप्वाइंट तकनीक पर रोक सामान्य निष्पादन को रोकती है इसलिए अधिक समय लगता है। जबकि System.out को लिखना एप्लिकेशन के सामान्य निष्पादन प्रवाह के साथ बहुत हस्तक्षेप नहीं करता है, जो समय महत्वपूर्ण होने पर इसे बहुत मूल्यवान बनाता है।
निम्नलिखित System.out.println () का उपयोग करने के लिए सिंटैक्स है -
System.out.println("Debugging message");
सिंटैक्स के ऊपर उत्पन्न सभी संदेश वेब सर्वर लॉग फ़ाइल में लॉग इन होंगे।
संदेश लॉगिंग
मानक लॉगिंग विधि का उपयोग करके सभी डीबग, चेतावनी और त्रुटि संदेशों को लॉग करने के लिए उचित लॉगिंग विधि का उपयोग करना हमेशा महान विचार होता है। मैं सभी संदेशों को लॉग करने के लिए log4J का उपयोग करता हूं ।
सर्वलेट एपीआई लॉग () विधि का उपयोग करके जानकारी को आउटपुट करने का एक सरल तरीका भी प्रदान करता है -
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class ContextLog extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, java.io.IOException {
String par = request.getParameter("par1");
//Call the two ServletContext.log methods
ServletContext context = getServletContext( );
if (par == null || par.equals(""))
//log version with Throwable parameter
context.log("No message received:", new IllegalStateException("Missing parameter"));
else
context.log("Here is the visitor's message: " + par);
response.setContentType("text/html");
java.io.PrintWriter out = response.getWriter( );
String title = "Context Log";
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\">Messages sent</h2>\n" +
"</body>
</html>"
);
} //doGet
}
ServletContext अपने टेक्स्ट संदेशों को सर्वलेट कंटेनर की लॉग फ़ाइल में लॉग करता है। टॉमकैट के साथ ये लॉग <टॉमकैट-इंस्टॉलेशन-डायरेक्टरी> / लॉग्स में पाए जाते हैं।
लॉग फाइलें नई उभरती हुई बग या समस्याओं की आवृत्ति का संकेत देती हैं। इस कारण से अपवादों के कैच क्लॉज में लॉग () फ़ंक्शन का उपयोग करना अच्छा है जो कि सामान्य रूप से नहीं होना चाहिए।
JDB डीबगर का उपयोग करना
आप एक ही jdb कमांड के साथ सर्वलेट को डिबग कर सकते हैं जिसका उपयोग आप एप्लेट या एप्लिकेशन को डीबग करने के लिए करते हैं।
किसी सर्वलेट को डीबग करने के लिए, हम sun.servlet.http.HttpServer को डीबग करते हैं और ध्यान से देखते हैं क्योंकि HttpServer ब्राउज़र से किए गए HTTP अनुरोधों के जवाब में सर्वलेट निष्पादित करता है। यह बहुत ही समान है कि कैसे एप्लेट को डिबग किया जाता है। अंतर यह है कि एप्लेट्स के साथ, डिबग किया जा रहा वास्तविक कार्यक्रम sun.applet.AppletViewer है।
अधिकांश डिबगर इस विवरण को स्वचालित रूप से एप्लेट डिबग करने का तरीका जानते हुए छिपाते हैं। जब तक वे सर्वलेट्स के लिए ऐसा नहीं करते हैं, आपको निम्नलिखित करके अपने डिबगर की मदद करनी होगी -
अपने डिबगर के क्लाथपथ को सेट करें ताकि वह sun.servlet.http.ttp -ttp- सर्वर और संबद्ध कक्षाओं को खोज सके।
अपने डिबगर के क्लाथ को सेट करें ताकि वह आपके सर्वलेट्स और सपोर्ट क्लासेस, आमतौर पर server_root / सर्वलेट्स और server_root / क्लासेस को भी खोज सके।
आप सामान्य रूप से अपने classpath में server_root / सर्वलेट नहीं चाहते हैं क्योंकि यह सर्वलेट पुनः लोड करने में अक्षम करता है। यह समावेश, हालांकि डिबगिंग के लिए उपयोगी है। यह आपके डिबगर को एक सर्वलेट में ब्रेकप्वाइंट सेट करने से पहले HttpServer में कस्टम सर्वलेट लोडर को सर्वलेट लोड करने की अनुमति देता है।
एक बार जब आप उचित वर्गपथ निर्धारित कर लें, तो sun.servlet.http.HttpServer डीबग करना प्रारंभ करें। आप डिबगिंग में रुचि रखने वाले किसी भी सर्वलेट में ब्रेकपॉइंट सेट कर सकते हैं, फिर दिए गए सर्वलेट (http: // localhost: 8080 / servlet / ServletToDebug) के लिए HttpServer से अनुरोध करने के लिए वेब ब्राउज़र का उपयोग करें। आपको अपने ब्रेकप्वाइंट पर निष्पादन को रोकना चाहिए।
टिप्पणियों का उपयोग करना
आपके कोड में टिप्पणियां विभिन्न तरीकों से डिबगिंग प्रक्रिया में मदद कर सकती हैं। डिबगिंग प्रक्रिया में टिप्पणियों का उपयोग कई अन्य तरीकों से किया जा सकता है।
सर्वलेट जावा टिप्पणियों और एकल लाइन (// ...) का उपयोग करता है और एकाधिक लाइन (/ * ... * /) टिप्पणियों का उपयोग आपके जावा कोड के कुछ हिस्सों को अस्थायी रूप से हटाने के लिए किया जा सकता है। यदि बग गायब हो जाता है, तो जिस कोड पर आपने टिप्पणी की है, उस पर करीब से नज़र डालें और समस्या का पता लगाएं।
क्लाइंट और सर्वर हेडर
कभी-कभी जब कोई सर्वलेट अपेक्षित व्यवहार नहीं करता है, तो यह कच्चे HTTP अनुरोध और प्रतिक्रिया को देखने के लिए उपयोगी होता है। यदि आप HTTP की संरचना से परिचित हैं, तो आप अनुरोध और प्रतिक्रिया पढ़ सकते हैं और देख सकते हैं कि वास्तव में उन हेडर के साथ क्या हो रहा है।
महत्वपूर्ण डिबगिंग युक्तियाँ
यहां सर्वलेट डीबगिंग के कुछ और डिबगिंग सुझावों की एक सूची दी गई है -
याद रखें कि server_root / कक्षाएं पुनः लोड नहीं होती हैं और वह server_root / सर्वलेट शायद करता है।
ब्राउज़र को उस पृष्ठ की कच्ची सामग्री दिखाने के लिए कहें जो वह प्रदर्शित कर रहा है। यह स्वरूपण समस्याओं की पहचान करने में मदद कर सकता है। यह आमतौर पर दृश्य मेनू के तहत एक विकल्प है।
सुनिश्चित करें कि पृष्ठ के पूर्ण पुनः लोड के लिए ब्राउज़र पिछले अनुरोध के आउटपुट को कैशिंग नहीं कर रहा है। नेटस्केप नेविगेटर के साथ, Shift-Reload का उपयोग करें; Internet Explorer के साथ Shift-Refresh का उपयोग करें।
सत्यापित करें कि आपका सर्वलेट इनिट () विधि एक सर्वलेटऑफिग पैरामीटर लेती है और सुपर.इनिट (कॉन्फ़िगरेशन) को तुरंत कॉल करती है।
इससे पहले कि हम आगे बढ़ें, मैं आपको तीन महत्वपूर्ण शर्तें समझाता हूँ -
Internationalization (i18n) - इसका मतलब है कि विज़िटर की भाषा या राष्ट्रीयता में अनुवादित सामग्री के विभिन्न संस्करण प्रदान करने के लिए एक वेब साइट को सक्षम करना
Localization (l10n) - इसका अर्थ है किसी विशेष भौगोलिक या सांस्कृतिक क्षेत्र के अनुकूल होने के लिए किसी वेब साइट पर संसाधन जोड़ना।
locale- यह एक विशेष सांस्कृतिक या भौगोलिक क्षेत्र है। इसे आमतौर पर एक देश के प्रतीक के बाद एक भाषा प्रतीक के रूप में संदर्भित किया जाता है जिसे एक अंडरस्कोर द्वारा अलग किया जाता है। उदाहरण के लिए "en_US" अमेरिका के लिए अंग्रेजी स्थान का प्रतिनिधित्व करता है।
वैश्विक वेबसाइट बनाते समय कई मदों पर ध्यान दिया जाना चाहिए। यह ट्यूटोरियल आपको इस पर पूर्ण विवरण नहीं देगा, लेकिन यह आपको एक अच्छा उदाहरण देगा कि आप अपने वेब पेज को विभिन्न भाषाओं में इंटरनेट समुदाय को उनके स्थान यानी लोकेल को अलग-अलग करके कैसे पेश कर सकते हैं।
एक सर्वलेट आवश्यककर्ता के स्थान के आधार पर साइट के उपयुक्त संस्करण को पिक कर सकता है और स्थानीय भाषा, संस्कृति और आवश्यकताओं के अनुसार उपयुक्त साइट संस्करण प्रदान कर सकता है। अनुरोध ऑब्जेक्ट का तरीका निम्नलिखित है जो लोकेल ऑब्जेक्ट लौटाता है।
java.util.Locale request.getLocale()
लोकेल का पता लगाना
निम्नलिखित महत्वपूर्ण स्थानीय विधियाँ हैं जिनका उपयोग आप आवश्यक स्थान, भाषा और निश्चित रूप से स्थान का पता लगाने के लिए कर सकते हैं। नीचे दिए गए सभी तरीके देश का नाम और भाषा का नाम आवश्यक ब्राउज़र में प्रदर्शित करते हैं।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | String getCountry() यह विधि आईएसओ 3166 2-अक्षर प्रारूप में इस स्थान के लिए ऊपरी मामले में देश / क्षेत्र कोड लौटाती है। |
2 | String getDisplayCountry() यह विधि उस स्थान के देश के लिए एक नाम देती है जो उपयोगकर्ता को प्रदर्शित करने के लिए उपयुक्त है। |
3 | String getLanguage() यह विधि ISO 639 प्रारूप में इस लोकेल के लिए निचले मामले में भाषा कोड लौटाती है। |
4 | String getDisplayLanguage() यह विधि उस स्थान की भाषा के लिए एक नाम देती है जो उपयोगकर्ता को प्रदर्शित करने के लिए उपयुक्त है। |
5 | String getISO3Country() यह विधि इस स्थानीय देश के लिए तीन-अक्षर का संक्षिप्त नाम देती है। |
6 | String getISO3Language() यह विधि इस स्थानीय भाषा के लिए तीन-अक्षर का संक्षिप्त नाम देती है। |
उदाहरण
यह उदाहरण दिखाता है कि आप अनुरोध के लिए भाषा और संबंधित देश कैसे प्रदर्शित करते हैं -
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.Locale;
public class GetLocale extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//Get the client's Locale
Locale locale = request.getLocale();
String language = locale.getLanguage();
String country = locale.getCountry();
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "Detecting Locale";
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\">" + language + "</h1>\n" +
"<h2 align = \"center\">" + country + "</h2>\n" +
"</body>
</html>"
);
}
}
भाषा सेटिंग
एक सर्वलेट एक पश्चिमी यूरोपीय भाषा जैसे अंग्रेजी, स्पेनिश, जर्मन, फ्रेंच, इतालवी, डच इत्यादि में लिखे गए पृष्ठ को आउटपुट कर सकता है। यहां सभी वर्णों को ठीक से प्रदर्शित करने के लिए ContentLanguage हेडर को सेट करना महत्वपूर्ण है।
दूसरा बिंदु HTML संस्थाओं का उपयोग करके सभी विशेष वर्णों को प्रदर्शित करना है, उदाहरण के लिए, "& # 241;" "ñ" का प्रतिनिधित्व करता है, और "& # 161;" निम्नानुसार "as" का प्रतिनिधित्व करता है:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.Locale;
public class DisplaySpanish extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
// Set spanish language code.
response.setHeader("Content-Language", "es");
String title = "En Español";
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>" + "En Español:" + "</h1>\n" +
"<h1>" + "¡Hola Mundo!" + "</h1>\n" +
"</body>
</html>"
);
}
}
लोकेल विशिष्ट तिथियां
आप java.text.DateFormat वर्ग और उसके स्थिर getDateTimeInstance () पद्धति का उपयोग तिथि और समय को स्थान विशेष के लिए कर सकते हैं। निम्नलिखित उदाहरण है जो दिखाता है कि किसी दिए गए स्थान के लिए विशिष्ट तिथियों को प्रारूपित कैसे करें -
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.Locale;
import java.text.DateFormat;
import java.util.Date;
public class DateLocale extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
//Get the client's Locale
Locale locale = request.getLocale( );
String date = DateFormat.getDateTimeInstance(DateFormat.FULL,
DateFormat.SHORT, locale).format(new Date( ));
String title = "Locale Specific Dates";
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\">" + date + "</h1>\n" +
"</body>
</html>"
);
}
}
स्थानीय विशिष्ट मुद्रा
आप java.txt.NumberFormat वर्ग और उसके स्थैतिक getCurrencyInstance () विधि का उपयोग कर एक नंबर को प्रारूपित कर सकते हैं, जैसे कि एक लंबी या डबल प्रकार, एक स्थानीय विशिष्ट मुद्रा में। निम्नलिखित उदाहरण है जो दिखाता है कि किसी दिए गए स्थान के लिए मुद्रा को प्रारूपित कैसे किया जाए -
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.Locale;
import java.text.NumberFormat;
import java.util.Date;
public class CurrencyLocale extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
//Get the client's Locale
Locale locale = request.getLocale( );
NumberFormat nft = NumberFormat.getCurrencyInstance(locale);
String formattedCurr = nft.format(1000000);
String title = "Locale Specific Currency";
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\">" + formattedCurr + "</h1>\n" +
"</body>
</html>"
);
}
}
लोकेल विशिष्ट प्रतिशत
आप java.txt.NumberFormat वर्ग और उसके स्थिर getPercentInstance () विधि का उपयोग लोकेल विशिष्ट प्रतिशत प्राप्त करने के लिए कर सकते हैं। निम्नलिखित उदाहरण है जो दिखाता है कि किसी दिए गए स्थान के लिए विशिष्ट प्रतिशत को कैसे प्रारूपित किया जाए -
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.Locale;
import java.text.NumberFormat;
import java.util.Date;
public class PercentageLocale extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
//Get the client's Locale
Locale locale = request.getLocale( );
NumberFormat nft = NumberFormat.getPercentInstance(locale);
String formattedPerc = nft.format(0.51);
String title = "Locale Specific Percentage";
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\">" + formattedPerc + "</h1>\n" +
"</body>
</html>"
);
}
}
अब तक, आपने यह जान लिया है कि कैसे सर्वलेट आपके एप्लिकेशन को वेब सर्वर में तैनात करने के लिए तैनाती डिस्क्रिप्टर (web.xml फ़ाइल) का उपयोग करता है। सर्वलेट एपीआई 3.0 ने javax.servlet.annotation नामक एक नया पैकेज पेश किया है। यह एनोटेशन प्रकार प्रदान करता है जिसका उपयोग सर्वलेट क्लास को एनोटेट करने के लिए किया जा सकता है। यदि आप एनोटेशन का उपयोग करते हैं, तो तैनाती डिस्क्रिप्टर (web.xml) की आवश्यकता नहीं है। लेकिन आपको tomcat7 या tomatat के किसी भी बाद के संस्करण का उपयोग करना चाहिए।
एनोटेशन वेब तैनाती वर्णनकर्ता फ़ाइल (web.xml) में समतुल्य XML विन्यास को सर्वलेट डिक्लेरेशन और सर्वलेट मैपिंग जैसे बदल सकते हैं। सर्वलेट कंटेनर परिनियोजित समय पर एनोटेट वर्गों को संसाधित करेगा।
सर्वलेट 3.0 में पेश किए गए एनोटेशन प्रकार हैं:
अनु क्रमांक। | एनोटेशन और विवरण |
---|---|
1 | @WebServlet एक सर्वलेट घोषित करने के लिए। |
2 | @WebInitParam एक इनिशियलाइज़ेशन पैरामीटर निर्दिष्ट करने के लिए। |
3 | @WebFilter सर्वलेट फिल्टर घोषित करने के लिए। |
4 | @WebListener एक WebListener घोषित करने के लिए |
5 | @HandlesTypes वर्ग प्रकार घोषित करने के लिए जो एक ServletContainerInitializer संभाल सकता है। |
6 | @HttpConstraint यह एनोटेशन सभी HTTP प्रोटोकॉल विधियों पर लागू होने वाली सुरक्षा बाधाओं का प्रतिनिधित्व करने के लिए ServletSecurity एनोटेशन के भीतर उपयोग किया जाता है, जिसके लिए एक संगत HttpMethodConstraint तत्व सर्वलेट एनोटेशन के भीतर नहीं होता है। |
7 | @HttpMethodConstraint इस एनोटेशन का उपयोग सर्विसलेट सिक्योरिटी एनोटेशन के भीतर विशिष्ट HTTP प्रोटोकॉल संदेशों पर सुरक्षा बाधाओं का प्रतिनिधित्व करने के लिए किया जाता है। |
8 | @MultipartConfig एक सर्वलेट वर्ग पर निर्दिष्ट किया जा सकता है, यह दर्शाता है कि सर्वलेट के उदाहरणों से अनुरोध है कि मल्टीपार्ट / फॉर्म-डेटा MIME प्रकार के अनुरूप है। |
9 | @ServletSecurity यह एनोटेशन HTTP प्रोटोकॉल संदेशों पर सर्वलेट कंटेनर द्वारा लागू किए जाने के लिए सुरक्षा बाधाओं को निर्दिष्ट करने के लिए एक सर्वलेट कार्यान्वयन वर्ग पर उपयोग किया जाता है। |
यहां हमने कुछ एनोटेशन पर विस्तार से चर्चा की है।
@WebServlet
कंटेनर के साथ सर्वलेट के विन्यास को घोषित करने के लिए @WebServlet का उपयोग किया जाता है। निम्न तालिका में WebServlet एनोटेशन के लिए उपयोग की जाने वाली विशेषताओं की सूची है।
अनु क्रमांक। | विशेषता और विवरण |
---|---|
1 | String name सर्वलेट का नाम |
2 | String[] value URL पैटर्न का एरियर |
3 | String[] urlPatterns यह फ़िल्टर लागू होने वाले URL प्रतिमानों की सरणी |
4 | Int loadOnStartup पूर्णांक मूल्य आपको स्टार्टअप ऑर्डरिंग संकेत देता है |
5 | WebInitParam[] initParams इस सर्वलेट के लिए आरंभीकरण मापदंडों की सरणी |
6 | Boolean asyncSupported इस सर्वलेट द्वारा समर्थित अतुल्यकालिक ऑपरेशन |
7 | String smallIcon इस सर्वलेट के लिए छोटा आइकन, यदि मौजूद है |
8 | String largeIcon इस सर्वलेट के लिए बड़ा आइकन, यदि मौजूद है |
9 | String description इस सर्वलेट का विवरण, यदि उपस्थित हो |
10 | String displayName यदि मौजूद हो तो इस सर्वलेट का नाम प्रदर्शित करें |
दोनों में से कम से कम एक URL पैटर्न घोषित होना चाहिए value या urlPattern एनोटेशन की विशेषता, लेकिन दोनों नहीं।
value विशेषता का उपयोग करने के लिए अनुशंसित किया जाता है जब URL पैटर्न एकमात्र विशेषता सेट किया जा रहा हो, अन्यथा urlPattern विशेषता का उपयोग किया जाना चाहिए।
उदाहरण
निम्न उदाहरण बताता है कि @WebServlet एनोटेशन का उपयोग कैसे करें। यह एक सरल सर्वलेट है जो पाठ को प्रदर्शित करता हैHello Servlet।
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(value = "/Simple")
public class Simple extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.print("<html><body>");
out.print("<h3>Hello Servlet</h3>");
out.print("</body></html>");
}
}
संकलन Simple.java सामान्य तरीके से और अपनी कक्षा की फ़ाइल को <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / कक्षाओं में डालें।
अब बस http: // localhost: 8080 / Simple चलाकर किसी भी सर्वलेट को कॉल करने का प्रयास करें । आप वेब पेज पर निम्न आउटपुट देखेंगे।
Hello servlet
@WebInitParam
@WebInitParam एनोटेशन का उपयोग सर्वलेट या फ़िल्टर के लिए इनिशियलाइज़ेशन पैरामीटर निर्दिष्ट करने के लिए किया जाता है। इसका उपयोग WebFilter या WebSevlet एनोटेशन के भीतर किया जाता है। निम्न तालिका में WebInitParam एनोटेशन के लिए उपयोग की जाने वाली विशेषताओं की सूची है।
अनु क्रमांक। | विशेषता और विवरण |
---|---|
1 | String name आरंभीकरण पैरामीटर का नाम |
2 | String value आरंभीकरण पैरामीटर का मान |
3 | String description आरंभीकरण पैरामीटर का विवरण |
उदाहरण
निम्न उदाहरण बताता है कि @WeInitParam एनोटेशन का उपयोग @WebServlet एनोटेशन के साथ कैसे करें। यह एक सरल सर्वलेट है जो पाठ को प्रदर्शित करता हैHello Servlet और स्ट्रिंग मान Hello World! जो से लिया जाता है init मापदंडों।
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(value = "/Simple", initParams = {
@WebInitParam(name = "foo", value = "Hello "),
@WebInitParam(name = "bar", value = " World!")
})
public class Simple extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.print("<html><body>");
out.print("<h3>Hello Servlet</h3>");
out.println(getInitParameter("foo"));
out.println(getInitParameter("bar"));
out.print("</body></html>");
}
}
संकलन Simple.java सामान्य तरीके से और अपनी कक्षा की फ़ाइल को <Tomcat-installationdirectory>; / webapps / ROOT / WEB-INF / कक्षाओं में डालें।
अब बस http: // localhost: 8080 / Simple चलाकर किसी भी सर्वलेट को कॉल करने का प्रयास करें । आप वेब पेज पर निम्न आउटपुट देखेंगे।
Hello Servlet
Hello World!
@Webfilter
यह सर्वलेट फ़िल्टर घोषित करने के लिए उपयोग किया जाने वाला एनोटेशन है। यह कंटेनर द्वारा परिनियोजन समय पर संसाधित किया जाता है, और निर्दिष्ट URL पैटर्न, सर्वलेट्स और डिस्पैचर प्रकारों पर लागू होने वाला संबंधित फ़िल्टर।
@WebFilterएनोटेशन एक वेब एप्लिकेशन में एक फिल्टर को परिभाषित करता है। यह एनोटेशन एक वर्ग पर निर्दिष्ट होता है और इसमें फ़िल्टर घोषित किए जाने के बारे में मेटाडेटा होता है। एनोटेट किए गए फ़िल्टर में कम से कम एक URL पैटर्न होना चाहिए। निम्न तालिका वेबफिल्टर एनोटेशन के लिए उपयोग की जाने वाली विशेषताओं को सूचीबद्ध करती है।
अनु क्रमांक। | विशेषता और विवरण |
---|---|
1 | String filterName फिल्टर का नाम |
2 | String[] urlPatterns मान या urlPatterns की सरणी प्रदान करता है जिस पर फ़िल्टर लागू होता है |
3 | DispatcherType[] dispatcherTypes डिस्पैचर के प्रकार (रिक्वेस्ट / रिस्पांस) को निर्दिष्ट करता है, जिस पर फ़िल्टर लागू होता है |
4 | String[] servletNames सर्वलेट नामों की एक सरणी प्रदान करता है |
5 | String displayName फिल्टर का नाम |
6 | String description फ़िल्टर का वर्णन |
7 | WebInitParam[] initParams इस फिल्टर के लिए आरंभीकरण मापदंडों की सरणी |
8 | Boolean asyncSupported इस फिल्टर द्वारा समर्थित अतुल्यकालिक ऑपरेशन |
9 | String smallIcon इस फ़िल्टर के लिए छोटा आइकन, यदि मौजूद हो |
10 | String largeIcon इस फिल्टर के लिए बड़ा आइकन, यदि मौजूद है |
उदाहरण
निम्न उदाहरण बताता है कि @WebFilter एनोटेशन का उपयोग कैसे करें। यह एक सरल लॉगफ़िल्टर है जो इनिट-परम के मूल्य को प्रदर्शित करता हैtest-paramऔर कंसोल पर वर्तमान समय टाइमस्टैम्प। इसका मतलब है, फ़िल्टर अनुरोध और प्रतिक्रिया के बीच एक इंटरफ़ेस परत की तरह काम करता है। यहां हम urlPattern के लिए "/ *" का उपयोग करते हैं। इसका मतलब है, यह फ़िल्टर सभी सर्वलेट्स के लिए लागू है।
import java.io.IOException;
import javax.servlet.annotation.WebFilter;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.*;
import java.util.*;
// Implements Filter class
@WebFilter(urlPatterns = {"/*"}, initParams = {
@WebInitParam(name = "test-param", value = "Initialization Paramter")})
public class LogFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
// Get init parameter
String testParam = config.getInitParameter("test-param");
//Print the init parameter
System.out.println("Test Param: " + testParam);
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// Log the current timestamp.
System.out.println("Time " + new Date().toString());
// Pass request back down the filter chain
chain.doFilter(request,response);
}
public void destroy( ) {
/* Called before the Filter instance is removed
from service by the web container*/
}
}
संकलन Simple.java सामान्य तरीके से और अपनी कक्षा की फ़ाइल को <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / कक्षाओं में डालें।
अब बस http: // localhost: 8080 / Simple चलाकर किसी भी सर्वलेट को कॉल करने का प्रयास करें । आप वेब पेज पर निम्न आउटपुट देखेंगे।
Hello Servlet
Hello World!
अब, सर्वलेट कंसोल खोलें। वहाँ, आप के मूल्य मिल जाएगाinit पैरामीटर testparam और यह current timestamp सर्वलेट अधिसूचना संदेशों के साथ।