AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Delphi REST Problem (Alles geht nur Delphi nicht)
Thema durchsuchen
Ansicht
Themen-Optionen

REST Problem (Alles geht nur Delphi nicht)

Ein Thema von t2000 · begonnen am 10. Jan 2022 · letzter Beitrag vom 11. Jan 2022
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von t2000
t2000

Registriert seit: 16. Dez 2005
Ort: NRW
232 Beiträge
 
Delphi 12 Athens
 
#1

REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 17:18
Hallo zusammen und ein gutes Neues

Wir haben ein Problem mit einem REST-API Zugriff auf den Zahlungsdienstleister PAYONE.
Vorab, wir sind dort Kunde und möchten einige Dinge über eine Zugriff über die REST API machen. Die relevanten Daten haben wir hier natürlich verfälscht.
Hier die Dokumentation von denen: https://docs.payone.com/display/publ...ce+Definitions

REST Zugriffe testen wir alle mit POSTMAN. Dort funktionieren die Bespiele auch und wir bekommen den angeforderten Kontakt.
Wir können die Abfrage im POSTMAN auf 2 unterschiedliche Arten machen
im Body als raw
oder als Parameter

POSTMAN macht dazu dann die folgende curl Abfrage
im Body als raw
Code:
curl --location --request POST 'https://api.pay1.de/post-gateway/' \
--header 'Content-Type: application/x-www-form-urlencoded;charset=UTF-8' \
--header 'Accept: application/json' \
--data-raw 'mid=88888&portalid=88888&key=0123456789abcdef0123456789abcdef&api_version=3.11&mode=live&request=getuser&encoding=UTF-8&aid=88888&type=userdata&customerid=88888'
als Parameter
Code:
curl --location --request POST 'https://api.pay1.de/post-gateway/' \
--header 'Content-Type: application/x-www-form-urlencoded;charset=UTF-8' \
--header 'Accept: application/json' \
--data-urlencode 'mid=88888' \
--data-urlencode 'portalid=888888' \
--data-urlencode 'key=0123456789abcdef0123456789abcdef' \
--data-urlencode 'api_version=3.11' \
--data-urlencode 'mode=live' \
--data-urlencode 'request=getuser' \
--data-urlencode 'encoding=UTF-8' \
--data-urlencode 'aid=88888' \
--data-urlencode 'type=userdata' \
--data-urlencode 'customerid=88888'
Beide Versionen laufen im POSTMAN einwandfrei

Im Delphi bekommen wir es mit den Komponenten TRESTClient, TRESTRequest, TRESTResponse nicht zum laufen.
Wir bekommen vom Anbieter immer 400 - Bad request

So in Delphi

im Body als raw

Delphi-Quellcode:
  LParameter := 'mid=88888&portalid=88888&key=0123456789abcdef0123456789abcdef&api_version=3.11&mode=live&request=getuser&encoding=UTF-8&aid=88888&type=userdata&customerid=88888';

  RESTClient1.BaseURL := 'https://api.pay1.de/post-gateway/';
  RESTClient1.Accept := 'application/json';
  RESTClient1.ContentType := 'application/x-www-form-urlencoded; charset=UTF-8';

  RESTRequest1.Method := rmPOST;

  RESTRequest1.AddParameter( 'Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8', TRESTRequestParameterKind.pkHTTPHEADER);
  RESTRequest1.AddParameter( 'Accept', 'application/json', TRESTRequestParameterKind.pkHTTPHEADER);
  RESTRequest1.AddBody( LParameter, TRESTContentType.ctNone); // wahlweise probiert
  RESTRequest1.AddBody( LParameter, TRESTContentType.ctTEXT_PLAIN); // wahlweise probiert

  try
    RESTRequest1.Execute; // request ausführen
  except
    on e: Exception do begin
      s := e.Message;
      memo1.lines.Add(s);
    end;
  end;
  s := RESTResponse1.StatusCode.ToString + ' / '  + RESTResponse1.Content;
  memo1.lines.Add(s);
als Parameter

Delphi-Quellcode:
  RESTClient1.BaseURL := 'https://api.pay1.de/post-gateway/';
  RESTClient1.Accept := 'application/json';
  RESTClient1.ContentType := 'application/x-www-form-urlencoded; charset=UTF-8';

  RESTRequest1.Method := rmPOST;

  RESTRequest1.AddParameter( 'Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8', TRESTRequestParameterKind.pkHTTPHEADER);
  RESTRequest1.AddParameter( 'Accept', 'application/json', TRESTRequestParameterKind.pkHTTPHEADER);

  LRequestKind := TRESTRequestParameterKind.pkURLSEGMENT; // wahlweise probiert
  LRequestKind := TRESTRequestParameterKind.pkGETorPOST; // wahlweise probiert
  LRequestOpt := []; // wahlweise probiert
  LRequestOpt := [TRESTRequestParameterOption.poDoNotEncode]; // wahlweise probiert

  RESTRequest1.AddParameter( 'mid', '88888', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'portalid', '88888', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'key', '0123456789abcdef0123456789abcdef', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'api_version', '3.11', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'mode', 'live', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'request', 'getuser', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'encoding', 'UTF-8', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'aid', '88888', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'type', 'userdata', LRequestKind, LRequestOpt);
  RESTRequest1.AddParameter( 'customerid', '88888', LRequestKind, LRequestOpt);

  try
    RESTRequest1.Execute; // request ausführen
  except
    on e: Exception do begin
      s := e.Message;
      memo1.lines.Add(s);
    end;
  end;
  s := RESTResponse1.StatusCode.ToString + ' / '  + RESTResponse1.Content;
  memo1.lines.Add(s);
Wir haben den gleichen Zugriff auch mit einem anderen Entwicklungspaket (WinDev) ausprobiert. Auch dort geht alles sofort einwandfrei.
Die Tests wurde auf 2 unterschiedlichen Computern gemacht. Auf beiden ist der POSTMAN in Ordnung und Delphi nicht.
Getestet wurde mit Delphi 10.4.2 und auch mit Delphi 11

Die REST Komponenten liegen auf der Form im Default Zustand. Ausprobiert haben wir nocht die Häkchen bei "SecureProtokols". Macht keinen unterschied.

Hat jemand ein Idee, wie wir das Problem finden können?

Vielen Dank
Thomas
(Wir suchen eine(n) Entwickler(in) mit Ambitionen später ggf. die Softwarefirma zu leiten)
Aktuell nicht mehr. Aber ab vielleicht 2024/2025 wird das wieder sehr interessant!
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
655 Beiträge
 
Delphi 12 Athens
 
#2

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 17:59
Du gibst den Content-Type und das Accept immer als "Parameter" mit. Das ist falsch, denn es sind Header-Felder im Request.

Du musst also die beiden Zeilen
Delphi-Quellcode:
  RestRequest.ContentType:=ctAPPLICATION_X_WWW_FORM_URLENCODED;
  RestRequest.Accept:='application/json';
einbauen und
Delphi-Quellcode:
  RESTRequest1.AddParameter( 'Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8', TRESTRequestParameterKind.pkHTTPHEADER);
  RESTRequest1.AddParameter( 'Accept', 'application/json', TRESTRequestParameterKind.pkHTTPHEADER);
rausschmeißen, dann sollte es hoffentlich klappen.
  Mit Zitat antworten Zitat
Benutzerbild von t2000
t2000

Registriert seit: 16. Dez 2005
Ort: NRW
232 Beiträge
 
Delphi 12 Athens
 
#3

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:12
Der TRestRequest hat keinen ContentType. Aber laut POSTMAN muss das "Entity" genau den ContentType haben.
Thomas
(Wir suchen eine(n) Entwickler(in) mit Ambitionen später ggf. die Softwarefirma zu leiten)
Aktuell nicht mehr. Aber ab vielleicht 2024/2025 wird das wieder sehr interessant!
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.087 Beiträge
 
Delphi 12 Athens
 
#4

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:18
... REST Zugriffe testen wir alle mit POSTMAN. ...
Ja das ist wohl die amtliche Referenz in dem Bereich.

Du könntest aber auch mal mit dem RestDebugger herumspielen.
Der ist normalerweise bei den Enterprise Version dabei ( beim im Source unter \Embarcadero\Studio\22.0\source\data\rest\restdebu gger\ ).
Jedenfalls kann der, wenn es funktioniert, direkt per CopyUndPaste die RestKomponenten erstellen, und erleichtert das Austesten ungemein.
  Mit Zitat antworten Zitat
Benutzerbild von t2000
t2000

Registriert seit: 16. Dez 2005
Ort: NRW
232 Beiträge
 
Delphi 12 Athens
 
#5

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:21
Der RestDebugger funktioniert auch nicht !!
Es muss eine Einmstellung bei der Delphi Komponente sein.
Alles anderen Tools, die wir bisher getestet haben, funktionieren.
Nur eben Delphi (eigene Source und auch RestDebugger) nicht.
Thomas
(Wir suchen eine(n) Entwickler(in) mit Ambitionen später ggf. die Softwarefirma zu leiten)
Aktuell nicht mehr. Aber ab vielleicht 2024/2025 wird das wieder sehr interessant!
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

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

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:28
Ohne weitere Recherche der Vorgaben und ohne Testmöglichkeit hätte ich jetzt diesen Ansatz gewählt:
Delphi-Quellcode:
  RESTClient1.BaseURL := 'https://api.pay1.de';
  RESTRequest1.Resource := 'post-gateway';
  RESTRequest1.Method := rmPOST;

  RESTRequest1.AddParameter( 'mid', '88888');
  RESTRequest1.AddParameter( 'portalid', '88888');
  RESTRequest1.AddParameter( 'key', '0123456789abcdef0123456789abcdef');
  RESTRequest1.AddParameter( 'api_version', '3.11');
  RESTRequest1.AddParameter( 'mode', 'live');
  RESTRequest1.AddParameter( 'request', 'getuser');
  RESTRequest1.AddParameter( 'encoding', 'UTF-8');
  RESTRequest1.AddParameter( 'aid', '88888');
  RESTRequest1.AddParameter( 'type', 'userdata');
  RESTRequest1.AddParameter( 'customerid', '88888');

  RESTRequest1.Execute;
Natürlich klappt das mit den obigen Daten erstmal nicht. Daher kann ich es auch nicht testen.

Das TRESTRequest.Execute überschreibt einige Parameter des Clients. Daher müssen diese Werte beim Request angegeben werden: Accept, HandleRedirects, AllowCookies, AcceptCharset, AcceptEncoding, ConnectTimeout, ReadTimeout

Der Default für den dritten und vierten Parameter bei AddParameter ist eh schon pkGETorPOST und []. Daher kann man die weglassen.

Der ContentType wird ebenfalls beim Execute intern anhand der übergebenen Parameter ermittelt. Bei rmPOST und pkGETorPOST wird schon der ContentType ctAPPLICATION_X_WWW_FORM_URLENCODED verwendet. Man braucht das also nicht mehr setzen (abgesehen davon, dass man das zumindest in 10.4.2 gar nicht kann).
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von SubData
SubData

Registriert seit: 14. Sep 2004
Ort: Stuhr
1.078 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:30
Lässt sich der Request vollständig mitloggen? Also inklusive aller Veränderungen, die die Komponente selbst vornimmt?
Ich erinnere mich, dass PayOne da durchaus ein wenig zickig sein kann, allerdings musste ich da nicht mit Delphi bei.
Ronny
/(bb|[^b]{2})/
  Mit Zitat antworten Zitat
Bbommel

Registriert seit: 27. Jun 2007
Ort: Köln
655 Beiträge
 
Delphi 12 Athens
 
#8

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:40
Der TRestRequest hat keinen ContentType. Aber laut POSTMAN muss das "Entity" genau den ContentType haben.
Ach shit, hatte nicht gesehen, dass ContentType beim RestRequest eine Funktion und keine Property ist, sorry.

Noch eine Idee: wenn du als Antwort ein 400 Bad Request bekommst, hast du dir für den Fall mal den Content der Antwort angeschaut? Manche Web Services liefern auch bei einem Fehler-Status einen Content, der manchmal sogar hilfreiche Fehlermeldungen enthält.
  Mit Zitat antworten Zitat
Benutzerbild von Sinspin
Sinspin

Registriert seit: 15. Sep 2008
Ort: Dubai
675 Beiträge
 
Delphi 10.3 Rio
 
#9

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 18:49
Wir haben es aufgegeben um Fehler in Delphi drumrumzuarbeiten. /NSoftware ist nicht ganz günstig, macht aber keine Zicken und lässt sich fast überall reingucken.
Stefan
Nur die Besten sterben jung
A constant is a constant until it change.
  Mit Zitat antworten Zitat
Benutzerbild von t2000
t2000

Registriert seit: 16. Dez 2005
Ort: NRW
232 Beiträge
 
Delphi 12 Athens
 
#10

AW: REST Problem (Alles geht nur Delphi nicht)

  Alt 10. Jan 2022, 19:54
Wir haben nun unzählige Versuche mit den unterschiedlichsten Möglichkeiten probiert.
Es gibt eine Version, die beim Überwachen mit FIDDLER die gleichen Daten anzeigt, wie es beim POSTMAN der Fall ist. Trotzdem funktioniert es nicht.
Beim POSTMAN werden die Daten um einen "PostmanToken" erweitert. Kann es sein, dass die Zieladresse (payone) etwas zurücksendet, was sofort beantwortet werden muss?

Für heute ist Feierabend. Morgen probieren wir es mit TMS Komponenten oder/und mit dem FDK von Frank.
Thomas
(Wir suchen eine(n) Entwickler(in) mit Ambitionen später ggf. die Softwarefirma zu leiten)
Aktuell nicht mehr. Aber ab vielleicht 2024/2025 wird das wieder sehr interessant!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 21:57 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