4. Esempio 03 – Chiavi di navigazione
4.1. Il progetto NetBeans
![]() |
- in [1]:
- [web.xml]: il file di configurazione dell'applicazione web
- [struts.xml]: il file di configurazione di Struts
- [Action1.java]: l'unica azione dell'applicazione
- [Page1.jsp, Page2.jsp]: le due viste dell'applicazione
- in [2]: visualizzazione di [Page1.jsp]
- in [3]: visualizzazione di [Page2.jsp]
4.2. Il file [struts.xml]
È il seguente:
<?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="default" namespace="/" extends="struts-default">
<default-action-ref name="index" />
<action name="index">
<result type="redirectAction">
<param name="actionName">Action1</param>
<param name="namespace">/actions</param>
</result>
</action>
</package>
<package name="actions" namespace="/actions" extends="struts-default">
<action name="Action1" class="actions.Action1">
<result name="page1">/vues/Page1.jsp</result>
<result name="page2">/vues/Page2.jsp</result>
</action>
</package>
</struts>
- righe 17-19: il metodo execute di [Action1] restituirà due chiavi di navigazione:
- page1, che visualizzerà la vista /views/Page1.jsp
- page2, che visualizzerà la vista /views/Page2.jsp
4.3. L'azione [Action1]
È simile a quella dell'esempio precedente:
package actions;
import com.opensymphony.xwork2.ActionSupport;
public class Action1 extends ActionSupport{
// action model
private String param1="valeur1";
private String param2="valeur2";
@Override
public String execute(){
// random selection between two views
int i=(int)(Math.random()*2);
if(i==0){
return "page1";
}else{
return "page2";
}
}
// getters and setters
...
}
- righe 12–14: Il metodo execute restituisce in modo casuale le chiavi previste page1 e page2.
4.4. Le pagine JSP
Page1.jsp
<%@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>Page1</title>
</head>
<body>
<h1>Page1</h1>
param1=<s:property value="param1"/><br/>
</body>
</html>
Riga 11: La pagina visualizza il valore del campo param1 da [Action1].
Page2.jsp
<%@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>Page2</title>
</head>
<body>
<h1>Page2</h1>
param2=<s:property value="param2"/><br/>
</body>
</html>
Riga 11: La pagina visualizza il valore del campo param2 da [Action1].
4.5. Test


Una volta che una delle pagine è aperta nel browser, è necessario aggiornarla (F5) per eseguire ripetutamente l'azione [Action1] fino a quando non appare l'altra pagina. È anche possibile passare dei parametri:

