Skip to content

4. Beispiel 03 – Navigationsschlüssel

4.1. Das NetBeans-Projekt

  • in [1]:
  • [web.xml]: die Konfigurationsdatei der Webanwendung
  • [struts.xml]: die Struts-Konfigurationsdatei
  • [Action1.java]: die einzige Aktion der Anwendung
  • [Page1.jsp, Page2.jsp]: die beiden Ansichten der Anwendung
  • in [2]: Anzeige von [Page1.jsp]
  • in [3]: Anzeige von [Page2.jsp]

4.2. Die Datei [struts.xml]

Sie sieht wie folgt aus:


<?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>
  • Zeilen 17–19: Die Methode „execute“ von [Action1] gibt zwei Navigationsschlüssel zurück:
  • page1, die die Ansicht /views/Page1.jsp anzeigt
  • page2, die die Ansicht /views/Page2.jsp anzeigt

4.3. Die Aktion [Action1]

Sie ähnelt der im vorherigen Beispiel:


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
...
}

  • Zeilen 12–14: Die Methode „execute“ gibt zufällig die erwarteten Schlüssel „page1“ und „page2“ zurück.

4.4. Die JSP-Ansichten

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>

Zeile 11: Die Seite zeigt den Wert des Feldes „param1“ aus [Action1] an.

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>

Zeile 11: Die Seite zeigt den Wert des Feldes „param2“ aus [Action1] an.

4.5. Testen

Image

Image

Sobald eine der Seiten im Browser geöffnet ist, müssen Sie sie aktualisieren (F5), um die Aktion [Action1] so lange wiederholt auszuführen, bis die andere Seite erscheint. Sie können auch Parameter übergeben:

Image