15. Exemplo 12 – Conversões e validações diversas
A nova aplicação permite a introdução de vários elementos que dispõem de validadores Struts:
![]() |
- em [1], o formulário de introdução de dados
- em [2], a confirmação dos dados introduzidos
A aplicação funciona de forma semelhante às anteriores, pelo que apenas comentaremos os pontos que diferem.
15.1. O projeto NetBeans
O projeto NetBeans é o seguinte:
![]() |
- em [1], as vistas da aplicação
- [Accueil.JSP]: a página inicial
- [FormDivers.JSP]: o formulário de introdução de dados
- [ConfirmationFormDivers.JSP]: a página de confirmação
- em [2], o ficheiro de mensagens [messages.properties] e o ficheiro de configuração principal do Struts
- em [3]:
- [FormDivers.java]: a ação que apresenta e processa o formulário
- [FormDivers-validation.xml]: as regras de validação da ação [FormDivers]. Este ficheiro delega essas validações ao modelo.
- [FormDiversModel]: o modelo da ação [FormDivers]
- [ FormDiversModel-validation.xml]: as regras de validação do modelo
- [FormDiversModel.properties]: o ficheiro de mensagens do modelo
- [example.xml]: ficheiro de configuração secundário do Struts
15.2. A configuração do projeto
O projeto é configurado principalmente pelo seguinte ficheiro [example.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>
<package name="example" namespace="/example" extends="struts-default">
<action name="Accueil">
<result name="success">/example/Accueil.JSP</result>
</action>
<action name="FormDivers" class="example.FormDivers">
<result name="input">/example/FormDivers.JSP</result>
<result name="cancel" type="redirect">/example/Accueil.JSP</result>
<result name="success">/example/ConfirmationFormDivers.JSP</result>
</action>
</package>
</struts>
É semelhante ao que foi analisado nas versões anteriores.
15.3. Os ficheiros de mensagens
O ficheiro [messages.properties] é o seguinte:
Accueil.titre=Accueil
Accueil.message=Struts 2 - Conversions et validations
Accueil.FormDivers=Saisies diverses (email, URL, chaine de caract\u00e8res avec contr\u00f4le du nombre de caract\u00e8res)
Form.titre=Conversions et validations
FormDivers.message=Struts 2 - Conversions et validations de types divers
Form.submitText=Valider
Form.cancelText=Annuler
Form.clearModel=Raz mod\u00e8le
Confirmation.titre=Confirmation
Confirmation.message=Confirmation des valeurs saisies
Confirmation.champ=champ
Confirmation.valeur=valeur
Confirmation.lien=Formulaire de test
xwork.default.invalid.fieldvalue=Valeur invalide pour le champ "{0}".
O ficheiro [FormDiversModel.properties] é o seguinte:
email.prompt=1-Tapez une adresse \u00E9lectronique (x@y.z)
email.error=Format invalide
URL.prompt=2-Tapez une URL (http://www.ibm.com)
URL.error=Format invalide
chaine.prompt=3-Tapez une chaine de 5 caract\u00E8res
chaine.error=Format invalide
15.4. O formulário de introdução de dados
A vista [FormDivers.JSP] é a seguinte:
<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<html>
<head>
<title><s:text name="Form.titre"/></title>
<s:head/>
</head>
<body background="<s:url value="/ressources/standard.jpg"/>">
<h2><s:text name="FormDivers.message"/></h2>
<s:form name="formulaire" action="FormDivers">
<s:textfield name="email" key="email.prompt" size="30"/>
<s:textfield name="URL1" key="URL.prompt" size="30"/>
<s:textfield name="chaine" key="chaine.prompt" size="10"/>
<s:submit key="Form.submitText" method="execute"/>
</s:form>
<br/>
<s:url id="URL" action="FormDivers" method="cancel"/>
<s:a href="%{URL}"><s:text name="Form.cancelText"/></s:a>
<br/>
<s:url id="URL" action="FormDivers" method="clearModel"/>
<s:a href="%{URL}"><s:text name="Form.clearModel"/></s:a>
</body>
</html>
As linhas 12 a 14 correspondem aos três campos de introdução de dados.
15.5. A vista de confirmação
A vista de confirmação [ConfirmationFormDivers.JSP] é a seguinte:
<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<html>
<head>
<title><s:text name="Confirmation.titre"/></title>
<s:head/>
</head>
<body background="<s:url value="/ressources/standard.jpg"/>">
<h2><s:text name="Confirmation.message"/></h2>
<table border="1">
<tr>
<th><s:text name="Confirmation.champ"/></th>
<th><s:text name="Confirmation.valeur"/></th>
</tr>
<tr>
<td><s:text name="email.prompt"/></td>
<td><s:text name="email"/></td>
</tr>
<tr>
<td><s:text name="URL.prompt"/></td>
<td><s:text name="URL1"/></td>
</tr>
<tr>
<td><s:text name="chaine.prompt"/></td>
<td><s:text name="chaine"/></td>
</tr>
</table>
<br/>
<s:url id="URL" action="FormDivers!input"/>
<s:a href="%{URL}"><s:text name="Confirmation.lien"/></s:a>
</body>
</html>
15.6. O modelo [FormDiversModel]
Os campos de introdução de dados do formulário [FormDivers.JSP] são inseridos no seguinte modelo [FormDiversModel]:
package example;
public class FormDiversModel {
// construtor sem parâmetros
public FormDiversModel() {
}
// campos
private String email;
private String URL1 ;
private String chaine;
// limpar modelo
public void clearModel() {
email = null;
URL1 = null;
chaine = null;
}
// getters e setters
...
}
15.7. A validação do modelo
A validação do modelo é controlada por dois ficheiros: [FormDivers-validation.xml] e [FormDiversModel-validation.xml].
O ficheiro [FormDivers-validation.xml] delega as validações ao seguinte ficheiro [FormDiversModel-validation.xml]:
<!--
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//
EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
-->
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//
EN" "http://localhost:8084/exemplo-10/example/xwork-validator-1.0.2.dtd">
<validators>
<field name="model" >
<field-validator type="visitor">
<param name="appendPrefix">false</param>
<message/>
</field-validator>
</field>
</validators>
Já nos deparámos com este ficheiro.
O ficheiro [FormDateModel-validation.xml] contém as seguintes regras de validação:
<!--
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//
EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
-->
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//
EN" "http://localhost:8084/exemplo-12/exemplo/xwork-validator-1.0.2.dtd">
<validators>
<field name="email" >
<field-validator type="requiredstring" short-circuit="true">
<message key="email.error"/>
</field-validator>
<field-validator type="email" short-circuit="true">
<message key="email.error"/>
</field-validator>
</field>
<field name="URL1" >
<field-validator type="requiredstring" short-circuit="true">
<message key="URL.error"/>
</field-validator>
<field-validator type="URL" short-circuit="true">
<message key="URL.error"/>
</field-validator>
</field>
<field name="chaine" >
<field-validator type="requiredstring" short-circuit="true">
<message key="chaine.error"/>
</field-validator>
<field-validator type="stringlength" short-circuit="true">
<param name="minLength">5</param>
<param name="maxLength">5</param>
<message key="chaine.error"/>
</field-validator>
</field>
</validators>
- linhas 11-18: verificam a validade do campo email
- linhas 15-17: verificam se a cadeia email é um endereço de e-mail válido
- linhas 20-27: verificam a validade do campo URL1
- linhas 24-26: verificam se a cadeia URL1 é um URL válido
- linhas 29-38: verificam a validade do campo chaine
- linhas 33-37: verificam se a cadeia chaine tem exatamente 5 caracteres.
15.8. A ação [FormDivers]
A ação [FormDivers] é a seguinte:
package example;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
import java.util.Map;
import org.apache.struts2.interceptor.SessionAware;
import org.apache.struts2.interceptor.validation.SkipValidation;
public class FormDivers extends ActionSupport implements ModelDriven, SessionAware {
// construtor sem parâmetros
public FormDivers() {
}
// modelo da ação
public Object getModel() {
if (session.get("model") == null) {
session.put("model", new FormDiversModel());
}
return session.get("model");
}
@SkipValidation
public String clearModel() {
// raz do modelo
((FormDiversModel) getModel()).clearModel();
// resultado
return INPUT;
}
public String cancel() {
// limpa-se o modelo
((FormDiversModel) getModel()).clearModel();
// resultado
return "cancel";
}
// SessionAware
Map<String, Object> session;
public void setSession(Map<String, Object> session) {
this.session = session;
}
}
A ação [FormDivers] segue o mesmo modelo das ações analisadas anteriormente. Neste caso, simplesmente não existe um método validate para complementar a validação efetuada pelo ficheiro [FormDiversModel-validation.xml].

