Hallo,
im Thread http://www.java-forum.org/allgemeine-java-themen/83243-java-server-faces-frage-zu-managedbeans.html habe ich bereits eine prinzipielle Frage zu JSF gepostet (ich habe den Thread aus versehen unter Allgemeines angelegt. Leider kann ich das nicht mehr ändern). Auf den dort beschriebenen Sachverhalt (die Terminverwaltung mit den Klassen Appointment, User, AppointmentHandler, UserHandler) bezieht sich auch meine Frage.
Bisher kann ich Termine anlegen und eine Übersicht der Termine anzeigen.
Die JSP-Seite zum Anlegen sieht u.a. wie folgt aus:
In der Action-Methode, die mit dem Button "Anlegen" verbunden ist wird entsprechend der Termin in der DB abgespeichert. Das funktioniert auch schon, ich kann also auf diese Weise Termine anlegen.
Die Übersicht der Termine ist über eine Tabellen-Ansicht realisiert. Mein UserHandler verfügt dazu neben der Entity für den User über ein DataModel, wie folgt skizziert.
Die JSP zum Anzeigen der Übersicht sieht wie folgt aus (bisschen abgekürzt damits nicht zu lang wird):
Das DataModel enthält jeweils Appointments. Das Anzeigen funktioniert auf diese Weise auch.
Nun wollte ich auch noch die Möglichkeit zur Verfügung stellen einen Termin ändern zu können. Dazu habe ich bisher einfach einen Button hinzugefügt (als h:column), so dass ich in einer zeile sagen kann: Bitte diesen Termin bearbeiten.
In der action-Methode zu diesem Button bestimme ich die Zeile die markiert ist bzw. den Termin der markiert ist, um ihm dann im AppointmentHandler setzen zu können:
Anschließend wird auf einer einzelnen Seite nur der ausgewählte Termin angezeigt, wobei ich die Daten dazu ändern kann. Die Seite ist mehr oder weniger identisch zur Seite zum Anlegen eines Termins (wieder ein Ausschnitt):
Nun stehen in description und shortdescription ja schon Werte drin. Das soll auch so sein, da ich ja die bisherigen Werte in den Textfeldern anzeigen möchte. Der Benutzer soll bei Bedarf aber einen Wert ändern können.
Wenn ich nun den Button zum Speichern drücke, wird die Änderung aber nicht tatsächlich übernommen. Wenn ich die Kurzbeschreibung von "Geburtstag Anne" in "Geburtstag" ändere, bleibt die Kurzbeschreibung des Termins auf "Geburtstag Anne". Ich habe auch mal einige Ausgaben in die Action-Methode eingebaut, um mir die Angaben zum Termin auszugeben, bevor ich den geänderten Termin in der DB speicher. Dort erscheinen die alten Werte und nicht die neuen! Es scheint fast so, als würden zwar die alten Werte in den Textfeldern angezeigt, aber als würden die neu eingetragenen Werte nicht übernommen werden.
Ich habe dann auch mal in getDescription und getShortDescription (von Appointment) Ausgaben eingebaut, da ich wissen wollte wann die Methoden aufgerufen werden. Zunächst hab ich einen Termin angelegt, um zu gucken ob die Ausgaben so sind wie ich es erwarte. Beim Betätigen des Action-Buttons werden wie erwartet die set-Methoden aufgerufen und der neue Termin wird richtig angelegt.
Wenn ich mir dann die Ausgaben beim Bearbeiten ansehe bin ich etwas überrascht. Zunächst werden die getter aufgerufen, da die Inhalte in den Textfeldern dargestellt werden sollen. Das ist ja richtig. Wenn ich aber den Button betätige wird keine (!) setter-Methode aufgerufen. Das verwundert mich doch sehr.
Hat irgendjemand eine Erklärung dafür? Ist es überhaupt legitim in den Managed Beans direkt auf die Entities zuzugreifen? Ich wäre für jegliche Hilfe wirklich sehr sehr dankbar.
Was ich dann noch probiert habe, ist folgendes: Bisher wird bei der Auswahl einer Zeile in der Übersicht ja der ausgewählte Termin bestimmt. Wenn ich dort nun nicht den ausgewählten Termin bestimme, sondern immer einen neuen ("leeren") Termin anlege, dann sollte sich die Bearbeiten-Methode eigentlich so verhalten wie die Anlegen-Methode - nach meinem bisherigen Verständnis. Das tut sie aber nicht, da dann beim Betätigen des Speichern-Buttons ein Fehler kommt das Beschreibung nicht null sein darf (selbst wenn ich einen Wert eingegeben habe).
im Thread http://www.java-forum.org/allgemeine-java-themen/83243-java-server-faces-frage-zu-managedbeans.html habe ich bereits eine prinzipielle Frage zu JSF gepostet (ich habe den Thread aus versehen unter Allgemeines angelegt. Leider kann ich das nicht mehr ändern). Auf den dort beschriebenen Sachverhalt (die Terminverwaltung mit den Klassen Appointment, User, AppointmentHandler, UserHandler) bezieht sich auch meine Frage.
Bisher kann ich Termine anlegen und eine Übersicht der Termine anzeigen.
Die JSP-Seite zum Anlegen sieht u.a. wie folgt aus:
Java:
<h:outputText value="Kurzbeschreibung"/>
<h:inputTextvalue="#{appointmentHandler.appointment.shortdescription}" />
<h:outputText value="Beschreibung"/>
<h:inputTextvalue="#{appointmentHandler.appointment.description}" />
In der Action-Methode, die mit dem Button "Anlegen" verbunden ist wird entsprechend der Termin in der DB abgespeichert. Das funktioniert auch schon, ich kann also auf diese Weise Termine anlegen.
Die Übersicht der Termine ist über eine Tabellen-Ansicht realisiert. Mein UserHandler verfügt dazu neben der Entity für den User über ein DataModel, wie folgt skizziert.
Java:
public class UserHandler {
private User user;
private DataModel resultModel;
...
Die JSP zum Anzeigen der Übersicht sieht wie folgt aus (bisschen abgekürzt damits nicht zu lang wird):
Java:
<h:dataTable id="data" style="width: 100%;" styleClass="standardTable" ... var="app" value="#{userHandler.resultModel}">
<h:column>
<f:facet name="header">
<h:outputText value="Beschreibung" />
</f:facet>
<h:outputText value="#{app.description}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Kurzbeschreibung" />
</f:facet>
<h:outputText value="#{app.shortdescription}" />
</h:column>
....
</h:dataTable>
Das DataModel enthält jeweils Appointments. Das Anzeigen funktioniert auf diese Weise auch.
Nun wollte ich auch noch die Möglichkeit zur Verfügung stellen einen Termin ändern zu können. Dazu habe ich bisher einfach einen Button hinzugefügt (als h:column), so dass ich in einer zeile sagen kann: Bitte diesen Termin bearbeiten.
In der action-Methode zu diesem Button bestimme ich die Zeile die markiert ist bzw. den Termin der markiert ist, um ihm dann im AppointmentHandler setzen zu können:
Java:
Appointment a = (Appointment) this.resultModel.getRowData();
FacesContext fc = FacesContext.getCurrentInstance();
fc.getApplication().createValueBinding("#{appointmentHandler.appointment}").setValue(fc, a);
Anschließend wird auf einer einzelnen Seite nur der ausgewählte Termin angezeigt, wobei ich die Daten dazu ändern kann. Die Seite ist mehr oder weniger identisch zur Seite zum Anlegen eines Termins (wieder ein Ausschnitt):
Java:
<h:outputText value="Kurzbeschreibung"/>
<h:inputTextvalue="#{appointmentHandler.appointment.shortdescription}" />
<h:outputText value="Beschreibung"/>
<h:inputTextvalue="#{appointmentHandler.appointment.description}" />
Nun stehen in description und shortdescription ja schon Werte drin. Das soll auch so sein, da ich ja die bisherigen Werte in den Textfeldern anzeigen möchte. Der Benutzer soll bei Bedarf aber einen Wert ändern können.
Wenn ich nun den Button zum Speichern drücke, wird die Änderung aber nicht tatsächlich übernommen. Wenn ich die Kurzbeschreibung von "Geburtstag Anne" in "Geburtstag" ändere, bleibt die Kurzbeschreibung des Termins auf "Geburtstag Anne". Ich habe auch mal einige Ausgaben in die Action-Methode eingebaut, um mir die Angaben zum Termin auszugeben, bevor ich den geänderten Termin in der DB speicher. Dort erscheinen die alten Werte und nicht die neuen! Es scheint fast so, als würden zwar die alten Werte in den Textfeldern angezeigt, aber als würden die neu eingetragenen Werte nicht übernommen werden.
Ich habe dann auch mal in getDescription und getShortDescription (von Appointment) Ausgaben eingebaut, da ich wissen wollte wann die Methoden aufgerufen werden. Zunächst hab ich einen Termin angelegt, um zu gucken ob die Ausgaben so sind wie ich es erwarte. Beim Betätigen des Action-Buttons werden wie erwartet die set-Methoden aufgerufen und der neue Termin wird richtig angelegt.
Wenn ich mir dann die Ausgaben beim Bearbeiten ansehe bin ich etwas überrascht. Zunächst werden die getter aufgerufen, da die Inhalte in den Textfeldern dargestellt werden sollen. Das ist ja richtig. Wenn ich aber den Button betätige wird keine (!) setter-Methode aufgerufen. Das verwundert mich doch sehr.
Hat irgendjemand eine Erklärung dafür? Ist es überhaupt legitim in den Managed Beans direkt auf die Entities zuzugreifen? Ich wäre für jegliche Hilfe wirklich sehr sehr dankbar.
Was ich dann noch probiert habe, ist folgendes: Bisher wird bei der Auswahl einer Zeile in der Übersicht ja der ausgewählte Termin bestimmt. Wenn ich dort nun nicht den ausgewählten Termin bestimme, sondern immer einen neuen ("leeren") Termin anlege, dann sollte sich die Bearbeiten-Methode eigentlich so verhalten wie die Anlegen-Methode - nach meinem bisherigen Verständnis. Das tut sie aber nicht, da dann beim Betätigen des Speichern-Buttons ein Fehler kommt das Beschreibung nicht null sein darf (selbst wenn ich einen Wert eingegeben habe).