स्प्रिंग - एमवीसी फ्रेमवर्क अवलोकन
स्प्रिंग वेब एमवीसी फ्रेमवर्क एक मॉडल-व्यू-कंट्रोलर आर्किटेक्चर और तैयार घटक प्रदान करता है जिसका उपयोग लचीला और शिथिल युग्मित वेब एप्लिकेशन विकसित करने के लिए किया जा सकता है। MVC पैटर्न इन तत्वों के बीच एक ढीली युग्मन प्रदान करते हुए एप्लिकेशन के विभिन्न पहलुओं (इनपुट लॉजिक, बिजनेस लॉजिक और UI लॉजिक) को अलग करता है।
Model अनुप्रयोग डेटा को एन्क्रिप्ट करता है और सामान्य रूप से, वे शामिल होंगे POJO।
View मॉडल डेटा प्रदान करने के लिए जिम्मेदार है और सामान्य तौर पर, यह उत्पन्न करता है HTML आउटपुट जो क्लाइंट के ब्राउज़र की व्याख्या कर सकता है।
Controller प्रसंस्करण के लिए जिम्मेदार है User Requests तथा Building Appropriate Model और इसे रेंडर करने के लिए दृश्य में पास करता है।
डिस्पैचरसर्वलेट
स्प्रिंग वेब मॉडल-व्यू-कंट्रोलर (MVC) फ्रेमवर्क एक डिस्पैचरसर्वलेट के आसपास डिज़ाइन किया गया है जो सभी HTTP अनुरोधों और प्रतिक्रियाओं को संभालता है। स्प्रिंग वेब MVC डिस्पैचरसर्वलेट का अनुरोध प्रसंस्करण वर्कफ़्लो निम्नलिखित चित्रण में दिखाया गया है।
DispatcherServlet पर आने वाले HTTP अनुरोध के अनुरूप घटनाओं का क्रम निम्न है -
HTTP अनुरोध प्राप्त करने के बाद, DispatcherServlet इस पर परामर्श देता है HandlerMapping उपयुक्त नियंत्रक को कॉल करने के लिए।
नियंत्रक अनुरोध लेता है और उपयोग के आधार पर उपयुक्त सेवा विधियों को कॉल करता है GET या POST method। सेवा पद्धति निर्धारित डेटा लॉजिक के आधार पर मॉडल डेटा सेट करेगी और डिस्पैसरस्लेट को रिटर्न नाम देगी।
DispatcherServlet से मदद लेंगे ViewResolver अनुरोध के लिए परिभाषित दृश्य चुनने के लिए।
एक बार जब दृश्य को अंतिम रूप दे दिया जाता है, तो द डिस्पैचर सेर्वलेट मॉडल डेटा को पास करता है, जो अंततः ब्राउज़रों पर प्रदान किया जाता है।
उपर्युक्त सभी घटक, यानी हैंडलर मैपिंग, नियंत्रक और ViewResolver के कुछ भाग हैं WebApplicationContext, जो मैदान का विस्तार है ApplicationContext वेब अनुप्रयोगों के लिए आवश्यक कुछ अतिरिक्त सुविधाओं के साथ।
आवश्यक कॉन्फ़िगरेशन
हमें URL मैपिंग का उपयोग करके डिस्पैचरसर्वलेट को हैंडल करने के लिए अनुरोध करने की आवश्यकता है web.xmlफ़ाइल। निम्नलिखित के लिए घोषणा और मानचित्रण दिखाने के लिए एक उदाहरण हैHelloWeb डिस्पैचरवर्क -
<web-app id = "WebApp_ID" version = "2.4"
xmlns = "http://java.sun.com/xml/ns/j2ee"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>Spring MVC Application</display-name>
<servlet>
<servlet-name>HelloWeb</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>HelloWeb</servlet-name>
<url-pattern>*.jsp</url-pattern>
</servlet-mapping>
</web-app>
web.xml फ़ाइल में रखा जाएगा WebContent/WEB-INFआपके वेब एप्लिकेशन की निर्देशिका। के आरंभीकरण परHelloWeb DispatcherServlet, रूपरेखा नाम की फ़ाइल से एप्लिकेशन संदर्भ को लोड करने का प्रयास करेगी [servlet-name]-servlet.xmlअनुप्रयोग के WebContent / WEB-INF निर्देशिका में स्थित है। इस मामले में, हमारी फाइल होगीHelloWeb-servlet.xml।
इसके बाद द <servlet-mapping>टैग इंगित करता है कि कौन से URL को किस DispatcherServlet द्वारा संभाला जाएगा। यहां, .jsp के साथ समाप्त होने वाले सभी HTTP अनुरोधों को नियंत्रित किया जाएगाHelloWeb DispatcherServlet।
यदि आप डिफ़ॉल्ट फ़ाइल नाम के साथ नहीं जाना चाहते हैं [servlet-name]-servlet.xml और WebContent / WEB-INF के रूप में डिफ़ॉल्ट स्थान, आप सर्वलेट श्रोता को जोड़कर इस फ़ाइल का नाम और स्थान अनुकूलित कर सकते हैं ContextLoaderListener अपने web.xml फ़ाइल में निम्नानुसार है -
<web-app...>
<!-------- DispatcherServlet definition goes here----->
....
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/HelloWeb-servlet.xml</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
</web-app>
अब, हम के लिए आवश्यक विन्यास की जाँच करें HelloWeb-servlet.xml फ़ाइल, आपके वेब एप्लिकेशन के WebContent / WEB-INF निर्देशिका में रखी गई है।
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:context = "http://www.springframework.org/schema/context"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package = "com.tutorialspoint" />
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
</beans>
निम्नलिखित कुछ महत्वपूर्ण बिंदु हैं HelloWeb-servlet.xml फ़ाइल -
[servlet-name]-servlet.xml फ़ाइल को वैश्विक दायरे में एक ही नाम से परिभाषित किसी भी सेम की परिभाषाओं को पछाड़ते हुए, बीन्स को बनाने के लिए उपयोग किया जाएगा।
<context:component-scan...> टैग का उपयोग स्प्रिंग MVC एनोटेशन स्कैनिंग क्षमता को सक्रिय करने के लिए किया जाएगा, जो एनोटेशन जैसे उपयोग करने की अनुमति देता है @Controller तथा @RequestMapping, आदि।
InternalResourceViewResolverदृश्य नामों को हल करने के लिए परिभाषित नियम होंगे। उपर्युक्त परिभाषित नियम के अनुसार, एक तार्किक नामhello एक दृश्य कार्यान्वयन पर स्थित है /WEB-INF/jsp/hello.jsp।
आइए अब समझते हैं कि वास्तविक घटक यानी कंट्रोलर, मॉडल और व्यू कैसे बनाएं।
एक नियंत्रक को परिभाषित करना
DispatcherServlet विनियामकों को अनुरोध करता है कि वे इसके लिए विशिष्ट कार्यक्षमता को निष्पादित करें। @Controllerएनोटेशन इंगित करता है कि एक विशेष वर्ग एक नियंत्रक की भूमिका निभाता है। @RequestMapping एनोटेशन का उपयोग URL को पूरी कक्षा या किसी विशेष हैंडलर विधि के लिए मैप करने के लिए किया जाता है।
@Controller
@RequestMapping("/hello")
public class HelloController{
@RequestMapping(method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
@Controllerएनोटेशन एक वर्ग MVC नियंत्रक के रूप में परिभाषित करता है। यहाँ, का पहला उपयोग@RequestMapping इंगित करता है कि इस नियंत्रक पर सभी हैंडलिंग विधियों के सापेक्ष हैं /hello पथ।
अगला उद्घोष @RequestMapping (method = RequestMethod.GET) घोषित करने के लिए उपयोग किया जाता है printHello()HTTP GET अनुरोध को संभालने के लिए नियंत्रक की डिफ़ॉल्ट सेवा विधि के रूप में विधि। हम एक ही URL पर किसी भी POST अनुरोध को संभालने के लिए अन्य विधि को परिभाषित कर सकते हैं।
हम उपरोक्त नियंत्रक को दूसरे रूप में भी लिख सकते हैं, जहाँ हम @RequestMapping में अतिरिक्त विशेषताएँ जोड़ सकते हैं -
@Controller
public class HelloController{
@RequestMapping(value = "/hello", method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
value विशेषता उस URL को इंगित करती है जिससे हैंडलर विधि मैप की गई है और method HTTP HTTP GET अनुरोध को संभालने के लिए विशेषता सेवा पद्धति को परिभाषित करती है।
ऊपर दिए गए नियंत्रक के संबंध में कुछ महत्वपूर्ण बिंदु निम्नलिखित हैं -
आप एक सेवा पद्धति के अंदर आवश्यक व्यावसायिक तर्क को परिभाषित करेंगे। आप आवश्यकता के अनुसार इस विधि के अंदर एक और विधि कह सकते हैं।
परिभाषित व्यापार तर्क के आधार पर, आप इस पद्धति के भीतर एक मॉडल बनाएंगे। आप विभिन्न मॉडल विशेषताओं को सेट कर सकते हैं और इन विशेषताओं को परिणाम प्रस्तुत करने के लिए दृश्य द्वारा एक्सेस किया जाएगा। यह उदाहरण इसकी विशेषता "संदेश" के साथ एक मॉडल बनाता है।
एक परिभाषित सेवा पद्धति एक स्ट्रिंग लौटा सकती है, जिसमें का नाम शामिल है viewमॉडल प्रस्तुत करने के लिए उपयोग किया जाना है। यह उदाहरण तार्किक दृश्य नाम के रूप में "हैलो" देता है।
JSP व्यूज बनाना
स्प्रिंग एमवीसी विभिन्न प्रस्तुति प्रौद्योगिकियों के लिए कई प्रकार के विचारों का समर्थन करता है। इसमें शामिल है -JSPs, HTML, PDF, Excel Worksheets, XML, Velocity Templates, XSLT, JSON, Atom तथा RSS फ़ीड, JasperReports, आदि, हालांकि, सबसे आम जेएसटीएल के साथ लिखे गए JSP टेम्प्लेट हैं। तो, आइए हम /WEB-INF/hello/hello.jsp में एक सरल हेलो दृश्य लिखते हैं -
<html>
<head>
<title>Hello Spring MVC</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
यहाँ ${message}यहां वह विशेषता है, जिसे हमने नियंत्रक के अंदर सेटअप किया है। आपके पास अपने दृश्य के अंदर प्रदर्शित करने के लिए कई गुण हो सकते हैं।