स्प्रिंग एमवीसी - हिडन फील्ड उदाहरण

निम्न उदाहरण बताता है कि स्प्रिंग वेब MVC फ्रेमवर्क का उपयोग करके रूपों में छिपे हुए फ़ील्ड का उपयोग कैसे करें। इसके साथ शुरू करने के लिए, हमारे पास एक काम करने वाली ग्रहण आईडीई है और स्प्रिंग समर फ्रेमवर्क का उपयोग करके डायनामिक फॉर्म आधारित वेब एप्लिकेशन विकसित करने के लिए निम्नलिखित चरणों पर विचार करें।

कदम विवरण
1 स्प्रिंग एमवीसी - हैलो वर्ल्ड चैप्टर में बताए गए एक पैकेज com.tutorialspoint के तहत HelloWeb नाम से एक प्रोजेक्ट बनाएं।
2 जावा क्लासेज स्टूडेंट, स्टूडेंटकंट्रोलर को com.tutorialspoint पैकेज के तहत बनाएं।
3 Jsp उप-फ़ोल्डर के अंतर्गत view.jsp, result.jsp फ़ाइलें देखें।
4 अंतिम चरण स्रोत और कॉन्फ़िगरेशन फ़ाइलों की सामग्री बनाना और नीचे बताए अनुसार एप्लिकेशन को निर्यात करना है।

Student.java

package com.tutorialspoint;

public class Student {
   private Integer age;
   private String name;
   private Integer id;

   public void setAge(Integer age) {
      this.age = age;
   }
   public Integer getAge() {
      return age;
   }

   public void setName(String name) {
      this.name = name;
   }
   public String getName() {
      return name;
   }

   public void setId(Integer id) {
      this.id = id;
   }
   public Integer getId() {
      return id;
   }
}

StudentController.java

package com.tutorialspoint;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;

@Controller
public class StudentController {

   @RequestMapping(value = "/student", method = RequestMethod.GET)
   public ModelAndView student() {
      return new ModelAndView("student", "command", new Student());
   }
   
   @RequestMapping(value = "/addStudent", method = RequestMethod.POST)
   public String addStudent(@ModelAttribute("SpringWeb")Student student, 
      ModelMap model) {
      model.addAttribute("name", student.getName());
      model.addAttribute("age", student.getAge());
      model.addAttribute("id", student.getId());
      
      return "result";
   }
}

यहां, पहली सेवा पद्धति के लिए student(), हम एक रिक्त पारित किया है Studentobject"कमांड" नाम के साथ ModelAndView ऑब्जेक्ट में, क्योंकि स्प्रिंग फ्रेम "कमांड" नाम के साथ एक ऑब्जेक्ट की अपेक्षा करता है, यदि आप अपनी JSP फ़ाइल में <form: form> टैग का उपयोग कर रहे हैं। तो, जबstudent() विधि कहा जाता है, यह लौटाता है student.jsp राय।

दूसरी सेवा विधि addStudent() पर एक पोस्ट विधि के खिलाफ बुलाया जाएगा HelloWeb/addStudentयूआरएल। आप प्रस्तुत जानकारी के आधार पर अपना मॉडल ऑब्जेक्ट तैयार करेंगे। अंत में, एक "परिणाम" दृश्य सेवा पद्धति से वापस आ जाएगा, जिसके परिणामस्वरूप रेंडरिंग परिणाम होगा। jsp

student.jsp

<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
   <head>
      <title>Spring MVC Form Handling</title>
   </head>
   <body>

      <h2>Student Information</h2>
      <form:form method = "POST" action = "/HelloWeb/addStudent">
         <table>
            <tr>
              <td><form:label path = "name">Name</form:label></td>
              <td><form:input path = "name" /></td>
            </tr>
            <tr>
              <td><form:label path = "age">Age</form:label></td>
              <td><form:input path = "age" /></td>
            </tr>
            <tr>
              <td>< </td>
              <td><form:hidden path = "id" value = "1" /></td>
            </tr>
            <tr>
              <td colspan = "2">
                  <input type = "submit" value = "Submit"/>
              </td>
            </tr>
         </table>  
      </form:form>
   </body>
</html>

यहाँ, हम उपयोग कर रहे हैं <form:hidden /> HTML छिपा हुआ फ़ील्ड रेंडर करने के लिए टैग।

उदाहरण के लिए -

<form:hidden path = "id" value = "1"/>

यह HTML सामग्री के बाद रेंडर करेगा।

<input id = "id" name = "id" type = "hidden" value = "1"/>

result.jsp

<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
   <head>
      <title>Spring MVC Form Handling</title>
   </head>
   <body>

      <h2>Submitted Student Information</h2>
      <table>
         <tr>
            <td>Name</td>
            <td>${name}</td>
         </tr>
         <tr>
            <td>Age</td>
            <td>${age}</td>
         </tr>
         <tr>
            <td>ID</td>
            <td>${id}</td>
         </tr>
      </table>  
   </body>
</html>

एक बार जब आप स्रोत और कॉन्फ़िगरेशन फ़ाइल बनाने के साथ हो जाते हैं, तो अपने एप्लिकेशन को निर्यात करें। अपने आवेदन और उपयोग पर राइट क्लिक करेंExport → WAR File विकल्प और अपने सहेजें HelloWeb.war टॉमकैट के वेबैप फ़ोल्डर में फ़ाइल।

अब अपना टॉमकैट सर्वर शुरू करें और सुनिश्चित करें कि आप मानक ब्राउज़र का उपयोग करके वेबैप्स फ़ोल्डर से अन्य वेबपृष्ठों तक पहुँचने में सक्षम हैं। URL आज़माएं -http://localhost:8080/HelloWeb/student और हम निम्न स्क्रीन देखेंगे, यदि स्प्रिंग वेब एप्लिकेशन के साथ सब कुछ ठीक है।

आवश्यक जानकारी सबमिट करने के बाद, फॉर्म सबमिट करने के लिए सबमिट बटन पर क्लिक करें। हम निम्नलिखित स्क्रीन देखेंगे, यदि आपके स्प्रिंग वेब एप्लिकेशन के साथ सब कुछ ठीक है।