सर्वलेट्स - एनोटेशन

अब तक, आपने यह जान लिया है कि कैसे सर्वलेट आपके एप्लिकेशन को वेब सर्वर में तैनात करने के लिए तैनाती डिस्क्रिप्टर (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 प्रोटोकॉल संदेशों पर सुरक्षा बाधाओं का प्रतिनिधित्व करने के लिए ServletSecurity एनोटेशन के भीतर उपयोग किया जाता है।

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 सर्वलेट अधिसूचना संदेशों के साथ।