![]() |
AW: Client-Units für JSON-REST-Services erzeugen
Hmm..
Zitat:
Es gibt bei Vorhandensein (200) von Daten ein Object zurück, ansonsten (204) eben NIL. Somit sollte es immer eine Funktion sein, es muss halt geprüft werden, ob NIL zurück gegeben wurde. |
AW: Client-Units für JSON-REST-Services erzeugen
Zitat:
Als nächstes steht dann an noch einige Methoden ein wenig aufzuräumen und in andere Methoden auszulagern. Dann aber kann ich an die ersten Tests gehen. |
AW: Client-Units für JSON-REST-Services erzeugen
So, bisher ist die Syntax richtig, ich habe noch ein wenig aufgeräumt und es scheint zu funktionieren. Ich habe selbst kein ebay-developer-account und auch keine Möglichkeit das so einfach zu testen :) Ich werde mir aber mal was suchen, wo ich sehen kann ob das so geht wie ich möchte (und wenn ich mir selbst eben einen Service zusammenbaue).
Hier der erzeugte Quellcode aus dem Beispiel bisher: ![]() Verbesserungen die ich noch nicht beachtet habe: * Die Objekte sollten wieder automatisch freigegeben werden, die an den jeweiligen Objekten hängen. So ähnlich wie dies auch beispielsweise die WebService-Importer macht. * Methoden für Basic Auth und Oauth2, die zumindest den Token fest setzen lassen das man diesen nicht immer manuell über die Events setzen muss. |
AW: Client-Units für JSON-REST-Services erzeugen
Zitat:
Hallo zusammen. Wenn immer derselbe Client/Request/Response verwendet wird - wie verhält es sich bei massenhaft Requests? Wird das irgendwo gecacht? Angenommen es wird ein Request abgesetzt und es dauert sehr lange bis eine Response kommt. Kurz darauf wird der Request für eine andere Funktion aufgerufen. Gefühlsmässig würde ich pro Anfrage den Request und die Response erzeugen und am Ende wieder freigeben. Und die Response und Request jeweils der vorhandenenen RestClient Instanz zuweisen. Was meint Ihr? Beziehungsweise was gibt es für Erfahrungen? |
AW: Client-Units für JSON-REST-Services erzeugen
Standardmäßig nein,
außer es wurde extra eingebaut/aktiviert. Entweder das REST-Framework merkt sich die reinkommenden Parameter und das Ergebnis und bei Gleichheit wird ohne Aufruf Methode direkt das Ergebnis ausgeliefert. Aber wenn, dann wirst du das erst explizit aktivieren müssen, denn Funktionen alla "gib mit den aktuellen Wert/Summe/Zeit/..." sollen ja nicht immer das selbe Ergebnis liefern. Im DataSnap / RAD-Server gibt es auch einen Cache im Protokoll. So können Parameter/Daten vor Aufruf der Methode (vor dem Request) dort reingeladen werden, der es könnte das Result dort abgelegt werden (vor allem wenn viele Date/Werte raus kommen und das nur teilweise, unsortiert oder verzögert vom Client abgerfen wird) und wenn die Daten schon im Cache sind, dann könnte der nächste Aufruf das vorher prüfen und dann seine Arbeit abbrechen. Ich weiß aber nicht wie man diese Funktion nutzen kann. (hab's erst vor Kurzem bemerkt, als ich es im Protokollaufbau sah) Du kannst auch in deine Funktion sowas einbauen. Zu Beginn in einen Cache schauen und wenn möglich dann den Rest der Methode überspringen.
Delphi-Quellcode:
Und falls Result auch ein LeerString sein kann und der Cache sowas nicht speichern kann,
var Cache: TStringList; // möglichst Sorted=True oder ein sortiertes/inditiertes TDictory<T>
funktion TMyServerMethods.MyMethod(Param: string): string; begin //if Param = '' then // Exit(''); Result := Cache.Values[Param]; if Reuslt <> '' then Exit; ... Cache.Values[Param] := Result; end; dann muß man entweder damit Leben, dass die Methode in diesem Fall dennoch ausgeführt wird, oder man muß das Speichern/Auslesen bissl anpassen.
Delphi-Quellcode:
funktion TMyServerMethods.MyMethod(Param: string): string;
begin Result := Cache.Values[Param]; if Reuslt <> '' then begin if Reuslt = ' ' then Reuslt := '': Exit; end; ... if Result = '' then Result := ' '; Cache.Values[Param] := Result; end;
Delphi-Quellcode:
funktion TMyServerMethods.MyMethod(Param: string): string;
begin i := Cache.IndexOfName(Param); if i >= 0 then Exit(Cache.ValuesByIndex[i]); ... if Result = '' then begin Cache.Values[Param] := ''; Cache.Add(Param + Cache.NameValueSeparator); end else Cache.Values[Param] := Result; end; Etwas problematisch sind auch Fälle, wo der Request etwas dauert und mehrmals zeitgleich gleiche Anfragen rein kommen... Entweder man baut eine Synchronisierung ein (CriticalSection) oder selbst mit Cache sind die ersten Anfragen (auch nochmal nachdem der "alte" Wert aus dem Cache flog) somit gleichzeitig, da zu Beginn noch nichts im Cache war und es wird paralell mehrfach verarbeitet würde. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:00 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz