स्ट्रट्स 2 - मान्यताओं की रूपरेखा
इस अध्याय में, हम स्ट्रट्स सत्यापन ढांचे में गहराई से देखेंगे। स्ट्रट्स कोर में, हमारे पास सत्यापन ढांचा है जो कार्रवाई विधि निष्पादित होने से पहले सत्यापन करने के लिए नियमों को चलाने के लिए एप्लिकेशन को सहायता करता है।
ग्राहक पक्ष सत्यापन आमतौर पर जावास्क्रिप्ट का उपयोग करके हासिल किया जाता है। हालाँकि, ग्राहक के सत्यापन पर अकेले भरोसा नहीं करना चाहिए। सर्वोत्तम प्रथाओं का सुझाव है कि सत्यापन आपके आवेदन ढांचे के सभी स्तरों पर पेश किया जाना चाहिए। अब हम अपने स्ट्रट्स प्रोजेक्ट के सत्यापन को जोड़ने के दो तरीकों पर गौर करते हैं।
यहां, हम एक का उदाहरण लेंगे Employee जिनके नाम और उम्र को एक साधारण पृष्ठ का उपयोग करके कैप्चर किया जाना चाहिए, और हम यह सुनिश्चित करने के लिए इन दो मान्यताओं को रखेंगे कि उपयोगकर्ता हमेशा एक नाम और आयु दर्ज करता है जो 28 से 65 के बीच की सीमा में होना चाहिए।
आइए हम उदाहरण के मुख्य JSP पृष्ठ से शुरू करते हैं।
मुख्य पृष्ठ बनाएँ
हमें मुख्य पृष्ठ JSP फ़ाइल लिखें index.jsp, जिसका उपयोग ऊपर उल्लिखित कर्मचारी संबंधित जानकारी एकत्र करने के लिए किया जाएगा।
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Employee Form</title>
</head>
<body>
<s:form action = "empinfo" method = "post">
<s:textfield name = "name" label = "Name" size = "20" />
<s:textfield name = "age" label = "Age" size = "20" />
<s:submit name = "submit" label = "Submit" align="center" />
</s:form>
</body>
</html>
Index.jsp स्ट्रट्स टैग का उपयोग करता है, जिसे हमने अभी तक कवर नहीं किया है, लेकिन हम उन्हें टैग संबंधित अध्यायों में अध्ययन करेंगे। लेकिन अभी के लिए, बस यह मान लीजिए कि टेक्स्ट फ़ील्ड टैग एक इनपुट फ़ील्ड प्रिंट करता है, और एस: सबमिट प्रिंट बटन सबमिट करता है। हमने प्रत्येक टैग के लिए लेबल संपत्ति का उपयोग किया है जो प्रत्येक टैग के लिए लेबल बनाता है।
दृश्य बनाएँ
हम JSP फ़ाइल सफलता का उपयोग करेंगे। जेएसपी जो कि परिभाषित एक्शन रिटर्न SUCCESS में लागू किया जाएगा।
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Success</title>
</head>
<body>
Employee Information is captured successfully.
</body>
</html>
क्रिया बनाएँ
तो आइए हम एक छोटे एक्शन क्लास को परिभाषित करते हैं Employee, और फिर नामक विधि जोड़ें validate() जैसा कि नीचे दिखाया गया है Employee.javaफ़ाइल। सुनिश्चित करें कि आपका एक्शन क्लास विस्तारित होActionSupport वर्ग, अन्यथा आपकी मान्य विधि निष्पादित नहीं की जाएगी।
package com.tutorialspoint.struts2;
import com.opensymphony.xwork2.ActionSupport;
public class Employee extends ActionSupport {
private String name;
private int age;
public String execute() {
return SUCCESS;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void validate() {
if (name == null || name.trim().equals("")) {
addFieldError("name","The name is required");
}
if (age < 28 || age > 65) {
addFieldError("age","Age must be in between 28 and 65");
}
}
}
जैसा कि उपरोक्त उदाहरण में दिखाया गया है, सत्यापन विधि यह जांचती है कि 'नाम' फ़ील्ड में कोई मान है या नहीं। यदि कोई मूल्य नहीं दिया गया है, तो हम कस्टम त्रुटि संदेश के साथ 'नाम' फ़ील्ड के लिए एक फ़ील्ड त्रुटि जोड़ते हैं। दूसरे, हम जाँचते हैं कि 'आयु' फ़ील्ड के लिए दर्ज किया गया मान 28 और 65 के बीच है या नहीं, यदि यह शर्त पूरी नहीं होती है तो हम मान्य फ़ील्ड के ऊपर एक त्रुटि जोड़ते हैं।
कॉन्फ़िगरेशन फ़ाइलें
अंत में, हम सब कुछ एक साथ उपयोग करते हैं struts.xml विन्यास फाइल इस प्रकार है -
<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "true" />
<package name = "helloworld" extends = "struts-default">
<action name = "empinfo"
class = "com.tutorialspoint.struts2.Employee"
method = "execute">
<result name = "input">/index.jsp</result>
<result name = "success">/success.jsp</result>
</action>
</package>
</struts>
निम्नलिखित की सामग्री है web.xml फ़ाइल -
<?xml version = "1.0" Encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">
<display-name>Struts 2</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
अब, प्रोजेक्ट नाम पर राइट क्लिक करें और क्लिक करें Export > WAR Fileएक वार फाइल बनाने के लिए। फिर इस WAR को Tomcat की वेबऐप्स डायरेक्टरी में तैनात करें। अंत में, टॉमकैट सर्वर शुरू करें और URL तक पहुंचने का प्रयास करेंhttp://localhost:8080/HelloWorldStruts2/index.jsp। यह निम्न स्क्रीन का उत्पादन करेगा -
अब किसी भी आवश्यक जानकारी को दर्ज न करें, बस क्लिक करें Submitबटन। आप निम्न परिणाम देखेंगे -
आवश्यक जानकारी दर्ज करें लेकिन एक गलत फ़ील्ड दर्ज करें, हमें "टेस्ट" के रूप में नाम बताएं और 30 की उम्र, और अंत में क्लिक करें Submitबटन। आप निम्न परिणाम देखेंगे -
यह वैधता कैसे काम करती है?
जब उपयोगकर्ता सबमिट बटन दबाता है, तो स्ट्रट्स 2 स्वचालित रूप से मान्य विधि को निष्पादित करेगा और यदि कोई है “if”विधि के अंदर सूचीबद्ध कथन सत्य हैं, स्ट्रट्स 2 इसकी ऐडफिल्डर विधि कहेगा। यदि कोई त्रुटि जोड़ी गई है, तो स्ट्रट्स 2 निष्पादन विधि को कॉल करने के लिए आगे नहीं बढ़ेगा। बल्कि स्ट्रट्स 2 फ्रेमवर्क वापस आ जाएगाinput कार्रवाई को कॉल करने के परिणामस्वरूप।
इसलिए, जब सत्यापन विफल हो जाता है और स्ट्रट्स 2 रिटर्न करता है input, स्ट्रट्स 2 फ्रेमवर्क index.jsp फ़ाइल को फिर से परिभाषित करेगा। चूंकि, हमने स्ट्रट्स 2 फॉर्म टैग का उपयोग किया है, स्ट्रट्स 2 स्वचालित रूप से दर्ज किए गए फॉर्म के ऊपर त्रुटि संदेश जोड़ देगा।
ये त्रुटि संदेश वे हैं जिन्हें हमने AddFieldError विधि कॉल में निर्दिष्ट किया है। AddFieldError विधि में दो तर्क होते हैं। पहला, हैform फ़ील्ड नाम जिस पर त्रुटि लागू होती है और दूसरा, उस फॉर्म फ़ील्ड के ऊपर प्रदर्शित करने के लिए त्रुटि संदेश है।
addFieldError("name","The name is required");
के वापसी मूल्य को संभालने के लिए input हमें अपने एक्शन नोड में निम्नलिखित परिणाम जोड़ना होगा struts.xml।
<result name = "input">/index.jsp</result>
XML आधारित मान्यता
सत्यापन करने का दूसरा तरीका एक्शन क्लास के बगल में एक xml फ़ाइल रखकर है। Struts2 XML आधारित सत्यापन ईमेल सत्यापन, पूर्णांक श्रेणी सत्यापन, प्रपत्र सत्यापन फ़ील्ड, अभिव्यक्ति सत्यापन, regex सत्यापन, आवश्यक सत्यापन, सत्यापन सत्यापन, स्ट्रिंग-वेलिडेशन सत्यापन और आदि जैसे सत्यापन के अधिक विकल्प प्रदान करता है।
Xml फ़ाइल को नाम देने की आवश्यकता है '[action-class]'-validation.xml। इसलिए, हमारे मामले में हम एक फ़ाइल बनाते हैं जिसे कहा जाता हैEmployee-validation.xml निम्नलिखित सामग्री के साथ -
<!DOCTYPE validators PUBLIC
"-//OpenSymphony Group//XWork Validator 1.0.2//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
<validators>
<field name = "name">
<field-validator type = "required">
<message>
The name is required.
</message>
</field-validator>
</field>
<field name = "age">
<field-validator type = "int">
<param name = "min">29</param>
<param name = "max">64</param>
<message>
Age must be in between 28 and 65
</message>
</field-validator>
</field>
</validators>
XML फ़ाइल के ऊपर आपके CLASSPATH में आदर्श रूप से क्लास फ़ाइल के साथ रखा जाएगा। चलिए हमारे एम्प्लॉई एक्शन क्लास के रूप में निम्नानुसार हैvalidate() विधि -
package com.tutorialspoint.struts2;
import com.opensymphony.xwork2.ActionSupport;
public class Employee extends ActionSupport{
private String name;
private int age;
public String execute() {
return SUCCESS;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
बाकी सेटअप पहले जैसा है क्योंकि यह पिछले उदाहरण है, अब यदि आप एप्लिकेशन चलाएंगे, तो यह वही परिणाम देगा जो हमें पिछले उदाहरण में प्राप्त हुआ था।
कॉन्फ़िगरेशन को संग्रहीत करने के लिए xml फ़ाइल होने का लाभ एप्लिकेशन कोड से सत्यापन को अलग करने की अनुमति देता है। सत्यापन xml फ़ाइलों को बनाने के लिए आपको कोड और एक व्यापार विश्लेषक लिखने के लिए एक डेवलपर मिल सकता है। ध्यान देने योग्य बात यह है कि सत्यापनकर्ता प्रकार डिफ़ॉल्ट रूप से उपलब्ध हैं।
बहुत अधिक सत्यापनकर्ता हैं जो डिफ़ॉल्ट रूप से स्ट्रट्स के साथ आते हैं। सामान्य सत्यापनकर्ताओं में दिनांक मान्यकर्ता, रेगेक्स सत्यापनकर्ता और स्ट्रिंग लंबाई सत्यापनकर्ता शामिल हैं। अधिक विस्तार स्ट्रट्स के लिए निम्न लिंक की जाँच करें - XML आधारित मान्यताओं ।