सर्वलेट्स - एनोटेशन
अब तक, आपने यह जान लिया है कि कैसे सर्वलेट आपके एप्लिकेशन को वेब सर्वर में तैनात करने के लिए तैनाती डिस्क्रिप्टर (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 सर्वलेट अधिसूचना संदेशों के साथ।