7. Exemplo 05B – Navegação num formulário de introdução de dados
Analisamos um formulário que apresenta vários botões para submeter os dados introduzidos a uma ação.
![]() |
7.1. O projeto NetBeans
O projeto NetBeans é o seguinte:
![]() |
Os elementos do projeto são os seguintes:
- [DoSomething.JSP]: a única vista da aplicação que apresenta os três botões de navegação, bem como um link.
- [DoSomething.java] e [DoSomethingElse.java]: as duas ações do projeto
- [messages.properties]: o ficheiro de mensagens internacionalizadas
- [struts.xml]: o ficheiro de configuração do Struts 2
7.2. Configuration
O seguinte ficheiro [struts.xml] configura a aplicação:
<!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.custom.i18n.resources" value="messages" />
<package name="actions" namespace="/actions" extends="struts-default">
<action name="DoSomething" class="actions.DoSomething">
<result name="success">/vues/DoSomething.JSP</result>
</action>
<action name="DoSomethingElse" class="actions.DoSomethingElse">
<result name="success">/vues/DoSomething.JSP</result>
</action>
</package>
</struts>
- a ação [/actions/DoSomething] provocará a instanciação da classe [actions.DoSomething] e o seu método execute será executado por predefinição. Este comportamento por predefinição pode ser anulado se os parâmetros passados à ação [Something] especificarem outro método. Independentemente do método executado, este deverá devolver a chave de navegação success, uma vez que apenas esta chave foi definida. A vista [DoSomething.JSP] será então apresentada.
- A configuração da ação [/actions/DoSomethingElse] é idêntica.
7.3. O ficheiro de mensagens
O ficheiro de mensagens [messages.properties] é o seguinte:
formulaire.titre1=Actions et M\u00e9thodes
formulaire.titre2=Actions et M\u00e9thodes
formulaire.execute=DoSomething.execute
formulaire.action1=DoSomething.action1
formulaire.action2=DoSomethingElse.action2
formulaire.action3=DoSomething.action3
7.4. A vista [DoSomething.JSP]
A vista [DoSomething.JSP] é a seguinte:
![]() |
O seu código é o seguinte:
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title><s:text name="formulaire.titre1"/></title>
</head>
<body>
<h1><s:text name="formulaire.titre2"/></h1>
<s:form action="DoSomething">
<s:submit key="formulaire.execute"/>
<s:submit key="formulaire.action1" method="action1"/>
<s:submit key="formulaire.action2" action="DoSomethingElse" method="action2"/>
</s:form>
<s:url id="URL" action="DoSomething" method="action3"/>
<s:a href="%{URL}"><s:text name="formulaire.action3"/></s:a>
</body>
</html>
- linha 11: o formulário será enviado para a ação [DoSomething]. Isto não significa necessariamente que seja esta ação que venha a ser acionada. Depende do botão submit utilizado para o POST.
- linha 12: o botão submit não especifica nem ação nem método. Será a ação [DoSomething], especificada pela baliza <form>, que será instanciada. O método executado será aquele definido no ficheiro [struts.xml], ou seja, o método execute.
- linha 13: o botão submit especifica um método. Será a ação [DoSomething], especificada pela baliza <form>, que será instanciada. O método executado será o método action1.
- linha 14: o botão submit especifica uma ação e um método. Será a ação [DoSomethingElse] que será instanciada. O método executado será o método action2.
- linhas 16-17: uma ligação para a ação [DoSomething] e o método action3. A ação [DoSomething] será instanciada e o seu método action3 executado. Ao contrário dos botões submit, clicar no link não aciona um POST, mas sim um GET. Por conseguinte, não há nenhum parâmetro enviado.
O código HTML gerado por este código, quando se solicita o URL [http://localhost:8084/exemple-05B/actions/DoSomething.action], é o seguinte:
- linha 9: a baliza form do formulário HTML. O atributo action indica a URL para a qual serão enviados os parâmetros do formulário. Esta URL corresponde à ação [DoSomething].
- linhas 11, 13, 15: os atributos name dos botões serão enviados para a ação de destino do botão submit. É isto que permite ao Struts determinar a ação a instanciar e o método a executar.
- linha 13: o atributo name=method:action1 indica que o método DoSomething.action1 deve ser executado.
- linha 15: o atributo name= action:DoSomethingElse!action2 indica que o método DoSomethingElse.action2 deve ser executado.
- linha 11: o atributo name= formulaire.execute não especifica nem a ação nem o método. Por conseguinte, será executado o método DoSomething.execute.
- linha 19: o link solicita explicitamente a execução do método DoSomething.action3
7.5. As ações
A ação [DoSomething] é a seguinte:
package actions;
import com.opensymphony.xwork2.ActionSupport;
public class DoSomething extends ActionSupport {
public DoSomething() {
System.out.println("DoSomething");
}
@Override
public String execute() {
System.out.println("DoSomething.execute");
return SUCCESS;
}
public String action1() {
System.out.println("DoSomething.action1");
return SUCCESS;
}
public String action3() {
System.out.println("DoSomething.action3");
return SUCCESS;
}
}
- Os métodos execute, action1 e action3 escrevem na consola do servidor web e devolvem a chave de navegação success.
- linha 8: o construtor também escreve na consola do servidor web
As diferentes mensagens na consola permitem saber quais os métodos que são executados durante uma solicitação.
A ação [DoSomethingElse] é semelhante:
package actions;
import com.opensymphony.xwork2.ActionSupport;
public class DoSomethingElse extends ActionSupport {
public DoSomethingElse() {
System.out.println("DoSomethingElse");
}
@Override
public String execute() {
System.out.println("DoSomethingElse.execute");
return SUCCESS;
}
public String action2() {
System.out.println("DoSomethingElse.action2");
return SUCCESS;
}
}
7.6. Os testes
Os testes mostram os seguintes resultados (na consola do servidor web):
- ao clicar no botão [DoSomething.execute], a ação [DoSomething] é instanciada e o seu método execute é executado.
- ao clicar no botão [DoSomething.action1], a ação [DoSomething] é instanciada e o seu método action1 é executado.
- Ao clicar no botão [DoSomethingElse.action2], a ação [DoSomethingElse] é instanciada e o seu método action2 é executado.
- Ao clicar na ligação [DoSomething.action3], a ação [DoSomething] é instanciada e o seu método action3 é executado.

