रिचफेसेस - एरर हैंडलिंग
इस अध्याय में, हम विभिन्न त्रुटियों से निपटने के तरीकों के बारे में जानेंगे जिन्हें रिचफेसेस में लागू किया जा सकता है।
सर्वर साइड और क्लाइंट साइड एरर हैंडलिंग
हमें एक्शन क्लास आधारित अपवादों को संभालने के लिए सुंदर पुरानी जावा तकनीक (कोशिश / कैच) से गुजरना होगा। क्लाइंट पक्ष के लिए, हम एक अतिरिक्त फ़ाइल जोड़ सकते हैं, जो क्लाइंट पक्ष पर कोई त्रुटि होने पर त्रुटि संदेश दिखाएगा।
कोड स्निपेट को क्लाइंट पक्ष की त्रुटियों को संभालने के लिए web.xml में जोड़ा जा सकता है।
<error-page>
<exception-type>java.lang.Throwable</exception-type>
<location>/error.xhtml</location>
</error-page>
ध्यान दें, उपरोक्त अपवाद केवल स्थैतिक अपवाद संदेश प्रदान करेंगे और हमें गतिशील अपवाद संपत्ति का उपयोग करने के लिए JSF "ExceptionHandler" वर्ग का उपयोग करना पड़ सकता है। रनटाइम पर, रिचफेसेस इनपुट फ़ील्ड को मान्य करने के लिए कुछ सुविधाएँ प्रदान करता है, जिसका उपयोग एप्लिकेशन में अपवाद के प्राथमिक बिल्डिंग ब्लॉक के रूप में किया जा सकता है।
एक नई फ़ाइल बनाएं और उसमें निम्न कोड रखें।
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Error handling</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form id = "form">
<rich:panel>
<f:facet name = "header">
<h:panelGroup>
<h:outputText value = "Student Registration" />
<a4j:status>
<f:facet name = "start">
<h:graphicImage value = "/images/ai.gif" style = "height:12px;width:12px;" alt = "ai" />
</f:facet>
</a4j:status>
</h:panelGroup>
</f:facet>
<h:panelGrid columns = "3">
<h:outputText value = "Name:" />
<h:inputText value = "#{student.name}" id = "name" label = "name">
<f:validateLength minimum = "3" maximum = "8" />
<f:validateRequired />
<rich:validator />
</h:inputText>
<rich:message for = "name" />
<h:outputText value = "Email" />
<h:inputText value = "#{student.email}" id = "email"
validatorMessage = "Ivalid email address">
<f:validateRegex
pattern =
"^(([a-zA-Z0-9_\-\.]+)@([a-zA-Z0-9_\-\.]+)
\.([a-zAZ]{2,5}){1,25})+([;.](([a-zA-Z0-9_\-\.]+)
@([a-zA-Z0-9_\-\.]+)\.([a-zAZ]{2,5}){1,25})+)*$" />
<rich:validator />
</h:inputText>
<rich:message for = "email" />
<h:outputText value = "Age" />
<h:inputText value = "#{student.age}" id = "age" label = "age">
<f:validateLongRange minimum = "18" maximum = "99" />
<rich:validator />
</h:inputText>
<rich:message for = "age" />
</h:panelGrid>
</rich:panel>
</h:form>
</h:body>
</html>
निम्नलिखित की तरह सामान्य वर्ग का वर्ग होना चाहिए।
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class Student {
private String name;
private String email;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
उपरोक्त उदाहरण ब्राउज़र में निम्न आउटपुट प्राप्त करेगा, जब भी <h: form> में कोई त्रुटि होगी।
संसाधन लोड हो रहा है
रिचफेस जेएसएफ एप्लिकेशन में मानक संसाधन हैंडलिंग प्रक्रिया में सुधार करता है। इसे या तो रिसोर्ससर्वलेट को कॉन्फ़िगर करके या संसाधन अनुकूलन द्वारा लागू किया जा सकता है। रिसोर्ससर्वलेट को कॉन्फ़िगर करने के लिए, हमें web.xml में निम्नलिखित कोड को जोड़ना होगा।
<servlet>
<servlet-name>Resource Servlet</servlet-name>
<servlet-class>org.richfaces.webapp.ResourceServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Resource Servlet</servlet-name>
<url-pattern>/org.richfaces.resources/*</url-pattern>
</servlet-mapping>
हम JSF एप्लिकेशन में ऑप्टिमाइज़ेशन को भी सक्षम कर सकते हैं, जो विभिन्न जावास्क्रिप्ट और सीएसएस फाइलों को ऑप्टिमाइज़ करेगा। आवेदन में अनुकूलन प्राप्त करने के लिए हमें निम्नलिखित कोड जोड़ना होगा।
<context-param>
<param-name>org.richfaces.resourceOptimization.enabled</param-name>
<param-value>true</param-value>
</context-param>