Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Timeout bei Rest-Request verringern (https://www.delphipraxis.net/192625-timeout-bei-rest-request-verringern.html)

Der schöne Günther 5. Mai 2017 17:25

Delphi-Version: 10 Seattle

Timeout bei Rest-Request verringern
 
Ich habe meinen
Delphi-Quellcode:
TRestClient
und meinen
Delphi-Quellcode:
TRestRequest
. Ich muss mit einer Gegenstelle auf dem gleichen Rechner (http://localhost:12345/...) sprechen.

Und ich muss damit klar kommen dass diese Gegenstelle evtl. gar nicht läuft also z.B. der Port zu ist.

Mein Problem: Ich laufe immer auf einen festen Timeout dessen Länge ich nicht beeinflussen kann. Der
Delphi-Quellcode:
TRestRequest
hat beispielsweise eine
Delphi-Quellcode:
Timeout
-Property, aber da kann man setzen was man möchte, das scheint niemanden zu interessieren.

Der blockierende Aufruf ist die WinApi-Funktion
Delphi-Quellcode:
WinHttpSendRequest
in
Delphi-Quellcode:
System.Net.HttpClient.Win.pas
in der Methode
Delphi-Quellcode:
DoExecuteRequest(..)
.

Übersehe ich etwas? Ist das in späteren Versionen (Ich nutze Seattle) behoben? Der Linker hat sogar den Aufruf auf die entsprechende WinApi-Methode WinHttpSetTimeouts entfernt da sie im ganzen Programm nicht vorkommt :wall:

TiGü 8. Mai 2017 09:29

AW: Timeout bei Rest-Request verringern
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ich habe keinen konkreten Rat, aber läufst du in deiner Seattle-Version während des Execute in die procedure System.Net.HttpClient.Win TWinHTTPClient.CreateHandles?

So sieht das in Berlin Update 2 aus (man beachte den hässlichen Vergleich mit False):

Der schöne Günther 8. Mai 2017 09:33

AW: Timeout bei Rest-Request verringern
 
Bei "meinem" CreateHandles() fehlt der letzte Absatz komplett. Danke fürs testen. Schade. Für so etwas tue ich mir jetzt kein Update an...

TiGü 8. Mai 2017 09:36

AW: Timeout bei Rest-Request verringern
 
Alle Timeout-Properties haben übrigens den von mir festgelegten Wert, also das wird zumindest durchgereicht!

Der schöne Günther 8. Mai 2017 09:38

AW: Timeout bei Rest-Request verringern
 
Ja, das kam mit Berlin:

Zitat:

HTTP Connection Improvements
Two new timeouts: ConnectionTimeout and ResponseTimeout for the HTTP framework and component.
http://docwiki.embarcadero.com/RADSt...n_Improvements

TiGü 8. Mai 2017 10:17

AW: Timeout bei Rest-Request verringern
 
Habe gerade versucht mit der Rtti etwas zu spielen, aber da die Requests nur lokale Variablen in den jeweiligen Funktionen sind, kam ich auf die Schnelle nicht so ran.

Eine Idee wäre, dass du dich in WinHttpOpenRequest oder in WinHttpSendRequest einhängst und auf dem übergebenen Handle selbst die Funktion WinHttpSetTimeouts aufrufst.
Da gab es neulich irgendwo einen Blogbeitrag dazu und ich fands relativ unkompliziert...wie hieß das doch gleich?

TiGü 8. Mai 2017 10:21

AW: Timeout bei Rest-Request verringern
 
Ach ja, Delphi Detours Library:

Hier mal ein Beispiel, wo MessageBoxW gehookt wird:
https://github.com/MahdiSafsafi/delp...emo1/uMain.pas

Das sollte sich problemlos umsetzen lassen!

TiGü 8. Mai 2017 10:40

AW: Timeout bei Rest-Request verringern
 
Ja, easy! :-D

Delphi-Quellcode:
uses
  Winapi.Windows,
  Winapi.WinHTTP,
  DDetours;

var
  TrampolineWinHttpOpenRequest: function(hConnect: HINTERNET; pwszVerb: LPCWSTR; pwszObjectName: LPCWSTR; pwszVersion: LPCWSTR;
    pwszReferrer: LPCWSTR; ppwszAcceptTypes: PLPWSTR; dwFlags: DWORD): HINTERNET; stdcall = nil;

function InterceptWinHttpOpenRequest(hConnect: HINTERNET; pwszVerb: LPCWSTR; pwszObjectName: LPCWSTR; pwszVersion: LPCWSTR;
  pwszReferrer: LPCWSTR; ppwszAcceptTypes: PLPWSTR; dwFlags: DWORD): HINTERNET; stdcall;
begin
  Result := TrampolineWinHttpOpenRequest(hConnect, pwszVerb, pwszObjectName, pwszVersion, pwszReferrer, ppwszAcceptTypes, dwFlags);
  Winapi.WinHTTP.WinHttpSetTimeouts(Result, 10, 10, 10, 10); // Hier dann deine gewünschten Timeouts eingeben (vllt. über Class Property oder so!)
end;

procedure MakeMagic;
begin
  if not Assigned(TrampolineWinHttpOpenRequest) then
  begin
    @TrampolineWinHttpOpenRequest := InterceptCreate(@WinHttpOpenRequest, @InterceptWinHttpOpenRequest);
  end;
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:00 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz