VII. Exemple 05B - Navigation dans un formulaire de saisie▲
Nous étudions un formulaire présentant plusieurs boutons pour soumettre (submit) les données saisies à une action.
VII-A. Le projet Netbeans▲
Le projet Netbeans est le suivant :
Les éléments du projet sont les suivants :
- [DoSomething.jsp] : l'unique vue de l'application qui présente les trois boutons de navigation ainsi qu'un lien.
- [DoSomething.java] et [DoSomethingElse.java] : les deux actions du projet
- [messages.properties] : le fichier des messages internationalisés
- [struts.xml] : le fichier de configuration Struts 2
VII-B. Configuration▲
Le fichier [struts.xml] suivant configure l'application :
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
<!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>
- l'action [/actions/DoSomething] provoquera l'instanciation de la classe [actions.DoSomething] et sa méthode execute sera exécutée par défaut. Ce défaut peut être annulé si les paramètres passés à l'action [Something] précisent une autre méthode. Quelque soit la méthode exécutée, elle devra rendre la clé de navigation success puisque seule cette clé a été définie. La vue [DoSomething.jsp] sera alors affichée.
- la configuration de l'action [/actions/DoSomethingElse] est identique.
VII-C. Le fichier des messages▲
Le fichier des messages [messages.properties] est le suivant :
2.
3.
4.
5.
6.
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
VII-D. La vue [DoSomething.jsp]▲
La vue [DoSomething.jsp] est la suivante :
Son code est le suivant :
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
<%@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>
- ligne 11 : le formulaire sera posté à l'action [DoSomething]. Cela ne veut pas forcément dire que c'est cette action qui va être déclenchée. Cela dépend du bouton submit utilisé pour le POST.
- ligne 12 : le bouton submit ne précise ni action, ni méthode. Ce sera l'action [DoSomething] précisée par la balise <form> qui sera instanciée. La méthode exécutée sera celle définie dans le fichier [struts.xml], la méthode execute.
- ligne 13 : le bouton submit précise une méthode. Ce sera l'action [DoSomething] précisée par la balise <form> qui sera instanciée. La méthode exécutée sera la méthode action1.
- ligne 14 : le bouton submit précise une action et une méthode. Ce sera l'action [DoSomethingElse] qui sera instanciée. La méthode exécutée sera la méthode action2.
- lignes 16-17 : un lien vers l'action [DoSomething] et la méthode action3. L'action [DoSomething] sera instanciée et sa méthode action3 exécutée. Contrairement aux boutons submit, le clic sur le lien ne provoque pas un POST mais un GET. Il n'y a donc aucun paramètre posté.
Le code Html généré par ce code, lorsqu'on demande l'Url [http://localhost:8084/exemple-05B/actions/DoSomething.action] est le suivant :
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Actions et Méthodes</title>
</head>
<body>
<h1>Actions et Méthodes</h1>
<form ... action="/exemple-05B/actions/DoSomething.action" method="post">
...
<input type="submit" ... name="formulaire.execute" value="DoSomething.execute"/>
...
<input type="submit" ... name="method:action1" value="DoSomething.action1"/>
...
<input type="submit" ... name="action:DoSomethingElse!action2" value="DoSomethingElse.action2"/>
...
</form>
...
<a href="/exemple-05B/actions/DoSomething!action3.action">DoSomething.action3</a>
</body>
</html>
- ligne 9 : la balise form du formulaire Html. L'attribut action indique l'Url à laquelle seront postés les paramètres du formulaire. Cette Url est celle de l'action [DoSomething].
- lignes 11, 13, 15 : les attributs name des boutons seront postés à l'action cible du bouton submit. C'est ce qui permet à Struts de déterminer l'action à instancier et la méthode à exécuter.
- ligne 13 : l'attribut name=method:action1 indique que la méthode DoSomething.action1 doit être exécutée.
- ligne 15 : l'attribut name= action:DoSomethingElse!action2 indique que la méthode DoSomethingElse.action2 doit être exécutée.
- ligne 11 : l'attribut name= formulaire.execute ne précise ni action, ni méthode. C'est donc la méthode DoSomething.execute qui sera exécutée.
- ligne 19 : le lien demande explicitement l'exécution de la méthode DoSomething.action3
VII-E. Les actions▲
L'action [DoSomething] est la suivante :
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
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;
}
}
- les méthodes execute, action1 et action3 écrivent sur la console du serveur web et rendent la clé de navigation success.
- ligne 8 : le constructeur écrit également sur la console du serveur web
Les différentes écritures sur la console permettent de savoir quelles méthodes sont exécutées lors d'une requête.
L'action [DoSomethingElse] est similaire :
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
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;
}
}
VII-F. Les tests▲
Les tests montrent les résultats suivants (sur la console du serveur web) :
- lors d'un clic sur le bouton [DoSomething.execute], l'action [DoSomething] est instanciée et sa méthode execute exécutée.
- lors d'un clic sur le bouton [DoSomething.action1], l'action [DoSomething] est instanciée et sa méthode action1 exécutée.
- lors d'un clic sur le bouton [DoSomethingElse.action2], l'action [DoSomethingElse] est instanciée et sa méthode action2 exécutée.
- lors d'un clic sur le lien [DoSomething.action3], l'action [DoSomething] est instanciée et sa méthode action3 exécutée.


