Jörg Peschke: Konzeptfrage: Ajax-Rückmeldung

Beitrag lesen

Hallo,

Wie programmiert ihr Ajax- Anwendungen in Mehrbenutzer- Umgebung?

Eigentlich musst Du dann nur dem Client mitteilen, ob die Anforderung geklappt hat oder nicht.
Ich würde es so machen:

Bei einem AJAX-Request schickt der Server im Erfolg einen JavaScript-Funktionsaufruf zurück, der im Frontend genau die Änderung durchführt, die der Server gemacht hat.

Also z.b.

  
function loesche_Anwesenheit_Tag(verantaltungstag, weranstaltungs_id) {  
...  
}  

und der Server schickt
loesche_Anwesenheit_Tag(1,4711);

Für den Fehlerfall definierst Du einfach eine Fehlerfunktion z.b.:

  
function storno_error (message) {  
   alert ("Es ist folgender Fehler aufgetreten: "+message+", die Seite  
   wird neu geladen");  
   loaction.reload();  
}  

Passiert ein Fehler, weil die Daten nicht mehr konsistent sind (und ein User z.b. versucht eine Veranstaltung zu löschen, die es gar nicht mehr gibt), schickt der server:

storno_error ("Diese Veranstaltung existiert nicht: ");

Ist deine Server-Antwort XML-Basiert, musst du das nur in eine CDATA-Sektion schachteln, die du dann wieder auslesen kannst.

Jetzt musst Du beim Empfangen der AJAX-Antwort in Deiner onreadystatechange-Funtkion lediglich per Eval die Server-Antwort (also AJAXOBJEKT.responseText, bzw. bei XML-DOM responseXML, wenn Deine Antwort XML-basiert ist) ausführen.
Um Cross-Site-Scripting-Attacken zu verhindern kannst Du evtl. noch prüfen, ob die Server-Antwort einen sinnvollen Funktionsaufruf darstellt oder nicht.

-> Der User bekommt die Änderung im Frontend erst dann angezeigt, wenn sie auch wirklich durchgeführt wurde...ansonsten eine Fehlermeldung.
Wenn Du dem Benutzer dann noch anzeigst, dass gerade ein Ajax-request läuft(der typische Ladekreisel o.ä.), hast Du denke ich eine recht robuste, benutzerfreundliche Anwendung.

Wenn Du aber möchtest, dass das Ereignis "1 Benutzer hat was geändert, bitte auf allen Clients die Liste aktualisieren" an alle Benutzer verteilt wird: Sowas ist IMO mit HTTP nicht sinnvoll möglich.
Du könntest so etwas höchstens simulieren, z.b. in dem Du (wieder per Ajax) den Server peridisch fragst, ob die angezeigten Daten noch aktuell sind (z.b. durch Vergleich von zeitstempeln) - ist aber (finde ich) die weniger elegante Lösung und verursacht zudem unnötige serverlast.

Hope that helps,

Viele Grüße,

Jörg