सर्वलेट्स - त्वरित गाइड

सर्वलेट्स क्या हैं?

जावा सर्वलेट्स ऐसे प्रोग्राम हैं जो वेब या एप्लिकेशन सर्वर पर चलते हैं और वेब ब्राउजर या अन्य 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 सामान्य तरीके से और अपनी कक्षा की फ़ाइल अंदर डालें / Webapps / रूट / वेब-INF / कक्षाएं।

आइए हम अपवादों को संभालने के लिए 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&ntilde;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&ntilde;ol:" + "</h1>\n" +
               "<h1>" + "&iexcl;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 सर्वलेट अधिसूचना संदेशों के साथ।