17.14 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 bilden damit quasi das Backend der Webapplikation.
Beispiel Eine sehr einfache Bean, die eine Quadratzahl speichert. Sie ist in einem Paket unter dem Namen p gespeichert. Alle Beans sollten in Paketen liegen, da einige Servlet-Container mit Klassen im Standardpaket Schwierigkeiten haben.
Listing 17.13 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.14.1 Beans in JSP-Seiten anlegen, Attribute setzen und erfragen
In einer JSP kann diese Bean nun eingesetzt werden. Dazu muss zuerst 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 muss ein JavaBean-Objekt mit obiger Anweisung angelegt werden. Anschließend können die Aktionen <jsp:setProperty> und <jsp:getProperty> genutzt werden. Sie müssen nicht beide existieren, aber die entsprechende Methode muss 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" />
Wir können jetzt daran gehen, eine JSP zu schreiben, die aus dem Parameter param einen Wert ausliest und in der Bean speichert.
Listing 17.14 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.14.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, und ist dieser ungleich null, lässt er sich, wenn nötig, mit einer parseXXX()-Variante umwandeln. Anschließend lässt er sich 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. Dabei wird bei jsp:setProperty einfach das Attribut value weggelassen.
Schreiben wir daher unsere ersten Quadrat-Zeilen noch einmal um.
Listing 17.15 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 dann in der Bean gespeichert. Der Value stammt somit aus den mitgesendeten Daten.
Ist der Wert von propery="*", dann werden alle Eigenschaften aus den Parametern ausgelesen und entsprechende setXXX()-Funktion der Bean aufgerufen.
|