17.12 Beans
 
Eine JavaBean ist eine Softwarekomponente, deren Methoden nach einem Namensschema benannt sind. Für eine Eigenschaft XXX existieren die Methoden setXXX() oder getXXX(). Damit eine JSP nur die Visualisierung übernimmt, müssen die Daten (Model genannt) an einer anderen Stelle verwaltet werden. Für die Geschäftslogik gilt das gleiche. JavaBeans eignen sich ideal dafür. Sie stellen somit quasi das Backend der Webapplikation dar.
Beispiel Eine sehr einfache Bean, die eine Quadratzahl in einem Paket unter dem Namen p speichert. Alle Beans sollten in Paketen liegen, da einige Servlet-Container mit Klassen im Standardpaket Schwierigkeiten haben.
Listing 17.14
p/Quadrat.java
package p;
import java.io.Serializable;
public class Quadrat implements Serializable
{
private int zahl;
public void setZahl( int zahl )
{
this.zahl = zahl;
}
|
public int getZahl()
{
return zahl;
}
public int getQuadrat()
{
return zahl * zahl;
}
// kein
//
// public void setQuadrat( int quadrat )
}
|
17.12.1 Beans in JSP-Seiten anlegen, Attribute setzen und erfragen
 
In einer JSP lässt sich diese Bean nun einsetzen. Dazu muss zunächst ein Exemplar erzeugt werden. Hierfür dient der Tag <jsp:useBean>. Die Syntax lautet für unser Beispiel:
<jsp:useBean id="q" class="p.Quadrat" />
An dieser Stelle sei noch einmal auf die zwingende Einhaltung der Groß- und Kleinschreibung hingewiesen. Hat zum Beispiel ein Eingabefeld den Namen name, so lauten die dazugehörenden set- und get-Methoden setName() und getName(), genau in dieser Groß- beziehungsweise Kleinschreibweise.
Vor einem Zugriff müssen Sie ein JavaBean-Objekt mit obiger Anweisung anlegen. Anschließend können die Aktionen <jsp:setProperty> und <jsp:getProperty> genutzt werden. Es müssen nicht beide existieren, doch muss die entsprechende Methode in der Bean vorhanden sein. Belegen wir unsere Quadrat-Bean mit dem Wert 10, und fragen wir anschließend das Quadrat ab.
<jsp:setProperty name="q" property="zahl" value="10"/>
<jsp:getProperty name="q" property="quadrat" />.
Die allgemeine Syntax für den Zugriff über get und set lautet:
<jsp:setProperty name="beanname" property="attribut" value="wert" />
<jsp:getProperty name="beanname" property="attribut" />
Jetzt können wir daran gehen, eine JSP zu schreiben, die aus dem Parameter param einen Wert ausliest und in der Bean speichert.
Listing 17.15
bean.jsp, Teil 1
<jsp:useBean id="q" class ="p.Quadrat" />
<%
String param = request.getParameter( "param" );
int zahl = (param == null) ? 0 : Integer.parseInt( param );
%>
<jsp:setProperty name="q" property="zahl" value="<%=zahl%>"/>
Das Quadrat von <jsp:getProperty name="q" property ="zahl" />
ist <jsp:getProperty name="q" property ="quadrat" />.
Aufzurufen ist die JSP mit http://localhost:8080/jt/bean.jsp?param=12.
17.12.2 Der schnelle Zugriff auf Parameter
 
Der Zugriff auf die Parameter einer Anfrage und das Speichern des Attributs in der Bean ist eine häufig gestellte Aufgabe. Die bisherige Lösung sieht vor, mit request.getParameter() den Parameter zu erfragen. Ist dieser ungleich null, lässt er sich, wenn nötig, mit einer parseXXX()-Variante umwandeln und anschließend mit jsp:setProperty setzen. Müssen mehrere Eigenschaften in die Bean übertragen werden, ist das eine undankbare Aufgabe. Daher haben die Entwickler eine Abkürzung vorgesehen. Hier wird bei jsp:setProperty einfach das Attribut value weggelassen.
Schreiben wir daher unsere ersten Quadrat-Zeilen noch einmal um.
Listing 17.16
bean.jsp, Teil 2
<jsp:setProperty name="q" property ="zahl"/>
Das Quadrat von <jsp:getProperty name="q" property="zahl" />
ist <jsp:getProperty name="q" property="quadrat" />.
Aufzurufen ist es mit http://localhost:8080/jt/bean.jsp?param=14&zahl=11.
Damit wird der Wert direkt aus dem property-Parameter ausgelesen, automatisch konvertiert und in der Bean gespeichert. Der Value stammt somit aus den mitgesendeten Daten.
Ist der Wert von propery="*", werden alle Eigenschaften aus den Parametern ausgelesen und die entsprechende setXXX()-Funktion der Bean aufgerufen.
|