RichFaces - Gestion des erreurs
Dans ce chapitre, nous allons découvrir les différentes méthodes de gestion des erreurs qui peuvent être implémentées dans RichFaces.
Gestion des erreurs côté serveur et côté client
Nous devons passer par la très ancienne technique Java (try / Catch) pour gérer les exceptions basées sur la classe d'action. Pour le côté client, nous pouvons ajouter un fichier supplémentaire, qui affichera le message d'erreur chaque fois qu'une erreur s'est produite du côté client.
L'extrait de code suivant peut être ajouté dans web.xml afin de gérer les erreurs côté client.
<error-page>
<exception-type>java.lang.Throwable</exception-type>
<location>/error.xhtml</location>
</error-page>
Notez que l'exception ci-dessus ne fournira que des messages d'exception statiques et que nous devrons peut-être utiliser la classe JSF «ExceptionHandler» afin d'utiliser la propriété d'exception dynamique. Au moment de l'exécution, RichFaces fournit certaines fonctionnalités pour valider les champs d'entrée, qui peuvent être utilisées comme bloc de construction principal de l'exception dans l'application.
Créez un nouveau fichier et placez-y le code suivant.
<?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>
La classe java correspondante doit être une classe de bean normale comme la suivante.
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;
}
}
L'exemple ci-dessus donnera la sortie suivante dans le navigateur, chaque fois qu'il y aura une erreur dans le <h: form>.
Chargement des ressources
RichFaces améliore la procédure standard de gestion des ressources dans l'application JSF. Cela peut être implémenté en configurant ResourceServlet ou par l'optimisation des ressources. Pour configurer ResourceServlet, nous devons ajouter le morceau de code suivant dans 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>
Nous pouvons également activer l'optimisation dans l'application JSF, qui optimisera différents fichiers JavaScript et CSS. Nous devons ajouter le code suivant afin de réaliser l'optimisation dans l'application.
<context-param>
<param-name>org.richfaces.resourceOptimization.enabled</param-name>
<param-value>true</param-value>
</context-param>