AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein GUI-Design mit VCL / FireMonkey / Common Controls [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich
Thema durchsuchen
Ansicht
Themen-Optionen

[10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

Ein Thema von DeddyH · begonnen am 25. Apr 2016 · letzter Beitrag vom 25. Apr 2016
Antwort Antwort
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#1

[10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 11:11
Ich wollte gerade mein aktuelles Projekt testhalber auf 10.1 hochziehen. Dieses verwendet eine Datasnap-Verbindung über HTTP. Leider kommt diese nicht zustande, sondern bricht mit einer ENotImplemented-Exception ab. Nach langem Debuggen konnte ich auch die Ursache ermitteln: in der Unit Data.DBXHTTPLayer besitzt die Klasse TDBXHTTPLayer eine private Property vom Typ TDSHTTPClient. Innerhalb der Open-Methode von TDBXHTTPLayer werden Timeout-Werte für diese Property gesetzt. OK, der Setter ist recht unspektakulär:
Zitat:
Delphi-Quellcode:
procedure TDSHTTPClient.SetConnectTimeout(AMilisec: Integer);
begin
  // do nothing here
end;
Leider handelt es sich aber faktisch um eine Ableitung davon, nämlich TDSHTTPNativeClient (per ClassFactory instanziert, soweit ich sehen konnte). Hier ist der Setter überschrieben:
Zitat:
Delphi-Quellcode:
procedure TDSHTTPNativeClient.SetConnectTimeout(AMilisec: Integer);
begin
                                     
  raise ENotImplemented.Create('SetConnectTimeout');
end;
Für mich heißt das also: Originalunit ins Projektverzeichnis kopieren, dem Projekt hinzufügen und die Exceptions auskommentieren, oder kennt jemand noch einen anderen Weg? Try-Except dürfte nicht helfen, da dieser Block ja viel zu weit "außen" wäre, oder?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#2

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 11:49
Alternativ kannst du auch die entsprechenden Timeout-Werte in den DbxProperties auf 0 setzen oder leer machen, da sie ja eh nicht verwendet werden. Leider ist TDSHTTPNativeClient private, so daß eine abgeleitete Klasse davon, die den Fehler behebt, hier nicht in Frage kommt. Du kannst natürlich die gesamte Klassenimplementation kopieren, korrigieren (z.B. die entsprechenden Eigenschaften des FHTTPClient setzen) und dann in einer Ableitung von TDBXHTTPLayer instanzieren. Diese abgeleitete Layer-Klasse wird dann mittels TDBXCommunicationLayerFactory.RegisterLayer für HTTP registriert.

Wenn du mit den Defaultwerten von 60 Sekunden leben kannst, wäre das Leeren der DbxProperties noch der einfachste Weg.

Schreibst du einen Bugreport?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.176 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 11:55
Leider ist TDSHTTPNativeClient private, so daß eine abgeleitete Klasse davon, die den Fehler behebt, hier nicht in Frage kommt
Und bis Seattle hätte man jetzt einen class helper nehmen können.

(Tut mir leid, der musste jetzt sein).
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#4

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 12:30
Leider ist TDSHTTPNativeClient private, so daß eine abgeleitete Klasse davon, die den Fehler behebt, hier nicht in Frage kommt
Und bis Seattle hätte man jetzt einen class helper nehmen können.
Wie hättest du denn in Seattle für eine private Klasse (eine, die im Implementation-Teil deklariert ist) eine Ableitung schreiben wollen und wozu bräuchte man dafür einen Class Helper? Dieses Argument zieht genau hier nicht, da die relevanten Felder eben nicht private, sondern protected sind. Das Problem ist hier lediglich die Sichtbarkeit der Klasse und nicht der ihrer Felder.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#5

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 12:34
Und wenn man statt einer Exception einfach einen Hint ausgegeben hätte, müsste ich gar nichts tun, würde aber zur Designtime darauf hingewiesen, dass Timeouts nicht implementiert sind. Mal wieder prima gemacht
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#6

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 13:34
Und wenn man statt einer Exception einfach einen Hint ausgegeben hätte, müsste ich gar nichts tun, würde aber zur Designtime darauf hingewiesen, dass Timeouts nicht implementiert sind. Mal wieder prima gemacht
Wie gesagt: Bugreport schreiben!

Timeouts sind nichtsdestotrotz implementiert - man kann die Werte nur nicht über die DbxProperties ändern, sondern muss mit den Defaultwerten Vorlieb nehmen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#7

AW: [10.1 Berlin] Datasnap-Verbindung über HTTP nicht möglich

  Alt 25. Apr 2016, 15:15
Endlich nutze ich das neue QC auch mal: https://quality.embarcadero.com/browse/RSP-14296
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:05 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