AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

DHL-API mit RESTClient

Ein Thema von Ykcim · begonnen am 8. Jan 2025 · letzter Beitrag vom 10. Jan 2025
Antwort Antwort
Seite 4 von 4   « Erste     234   
Benutzerbild von DeddyH
DeddyH

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

AW: DHL-API mit RESTClient

  Alt Heute, 10:24
Die Demo von TUhr war ein SOAP-Request, der kann ja keine Lösung für ein REST-Problem sein . So wie ich es lese, war der Key seitens DHL noch gar nicht freigeschaltet, dann macht die Fehlermeldung natürlich Sinn.
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
Ykcim

Registriert seit: 29. Dez 2006
Ort: NRW
844 Beiträge
 
Delphi 10.4 Sydney
 
#32

AW: DHL-API mit RESTClient

  Alt Heute, 11:02
Das Beispiel von TUhr ist für meinen nächsten Schritt interessant, wenn ich versuche, über DHL API's Pakete zu versenden.
Aber da ich noch nie mit externen API's gearbeitet habe, wollte ich erst erst einmal die Sendungsverfolgung angehen, die ja viel einfacher ist.

Dabei ist mein Fehler gewesen, dass ich eine API verwendet habe, die nicht freigeschaltet war. Es war eine andere freigeschaltet, aber die ist für unsere Sendungen nicht verwendbar (vielleicht für die internationalen, ich habe es jetzt hier nur mit einer nationalen Sendungsnummer getestet).

Das heißt, dass ich jetzt im nächsten Schritt die funktionierende CURL in eine Delphi-App einbaue und versuchen werden, das ErgebnisJSON zu parsen. und wenn das funktioniert, werde ich mich mit TUhrs Demo an den eigentlichen Schritt wagen, und versuchen Pakete national / international zu versenden.

Aber Dank Eurer Unterstützung habe ich jetzt einen ersten Erfolg mit einer externen API - Vielen Dank!
Patrick
Patrick
  Mit Zitat antworten Zitat
Ykcim

Registriert seit: 29. Dez 2006
Ort: NRW
844 Beiträge
 
Delphi 10.4 Sydney
 
#33

AW: DHL-API mit RESTClient

  Alt Heute, 15:44
Hallo Zusammen,

ich habe das Ganze jetzt in einer kleinen Test-App mal versucht umzusetzen. Sicherlich noch nicht der Weisheit letzter Schluss, aber mal ein Ansatz... Das Ergebnis gebe ich in einem Memo und in einem StringGrid aus.

Delphi-Quellcode:
unit frmMain;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, REST.Types, Vcl.StdCtrls, System.JSON,
  REST.Client, AdvUtil, Vcl.Grids, AdvObj, BaseGrid, AdvGrid, Vcl.ExtCtrls;


type
   TRows = array of array of string; // [Cols, Rows]
   TCols = array of string;
  TForm1 = class(TForm)
    edtTrckngNr: TEdit;
    btnStrt: TButton;
    mmResult: TMemo;
    SG_Result: TAdvStringGrid;
    Panel1: TPanel;
    lblTrckngNr: TLabel;
    edtAPIKEY: TEdit;
    lblAPIKEY: TLabel;
    mmURL: TMemo;
    lblURL: TLabel;
    procedure btnStrtClick(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}


procedure FillAdvGrid(SG: TAdvStringGrid; Cols: TCols; Rows: TRows);
var
  i, j: Integer;
begin
   SG.Filter.Clear;
   SG.FilterActive:=false;
   SG.Clear;
   SG.FloatingFooter.Visible:=false;
   for i := 0 to SG.ColCount -1 do begin
      SG.Cols[i].BeginUpdate;
   end;
   if Assigned(Rows) then begin
      // Wir brauchen eine Zeile mehr für die Spaltenüberschriften
      SG.RowCount := length(Rows[0]) +1;
      SG.ColCount := length(Cols);
      SG.FixedRows := 0;
      // Spaltenüberschriften in die erste Zeile schreiben
      for i := 0 to length(Cols) - 1 do begin
         SG.Cols[i].Add(Cols[i]);
         SG.Cells[i, 0] := Cols[i];
      end;
      // zwei-dimensionales Zeilen-Array in den Zellen ausgeben
      for i := 0 to length(Cols) - 1 do begin
         for j := 0 to length(Rows[0]) - 1 do begin
            SG.Cells[i, j + 1] := Rows[i, j];
         end;
      end;
   end;
   for i := 0 to SG.ColCount -1 do begin
      SG.Cols[i].EndUpdate;
   end;
end;

procedure JSArrayToColsRows(Response: string; ArraySectionPath: string; var Cols: TCols; var Rows: TRows);
var JSValue: TJSONValue;
      JSObjEvent: TJSONObject;
      JSArryEvents: TJSONArray;
      I, J: integer;
begin
   JSValue:= TJSonObject.ParseJSONValue(Response);
   JSArryEvents:= TJSONArray(JSValue.FindValue(ArraySectionPath));
   for I := 0 to JSArryEvents.Count -1 do begin
      if JSArryEvents.Items[I] is TJSONObject then begin
         JSObjEvent := TJSONObject(JSArryEvents.Items[I]);
         SetLength(Cols, JSObjEvent.Count);
         SetLength(Rows, Length(Cols), I+1);
         for J := 0 to JSObjEvent.Count -1 do begin
            Cols[J]:= JSObjEvent.Pairs[J].JsonString.ToString;
            Rows[J, Length(Rows[0]) -1]:= JSObjEvent.Pairs[J].JsonValue.ToString;
         end;
      end;
   end;
end;

function cUrlCall (TrackNr, APIKEY: string; var URL: string; var Cols: TCols; var Rows: TRows): string;
var client : TRESTClient;
      request : TRESTRequest;
begin
   client := TRESTClient.Create('https://api-eu.dhl.com');
   try
      try
         request := TRESTRequest.Create(client);
         request.Method := rmGet;
         request.Resource := 'track/shipments';
         request.AddParameter('trackingNumber', TrackNr, pkGETorPOST, []);
         request.AddParameter('language', 'DE', pkGETorPOST, []);
         request.Params.AddItem('DHL-API-Key', APIKEY, pkHTTPHEADER, [poDoNotEncode]);
         URL:= request.GetFullRequestURL;
         request.Execute;
         JSArrayToColsRows(request.Response.Content, 'shipments[0].events', Cols, Rows);

         Result:= request.Response.Content;
      Except
         ON e: Exception do begin
            Result:= E.Message;
            ShowMessage('Keine Daten erhalten');
         end;
      end;
   finally
      client.Free;
   end;
end;

procedure TForm1.btnStrtClick(Sender: TObject);
var RequestResult: string;
      URL: string;
      Cols: TCols;
      Rows: TRows;
begin
   RequestResult:= cUrlCall(edtTrckngNr.Text, edtAPIKEY.Text, URL, Cols, Rows);
   mmURL.lines.Text:= URL;
   mmResult.Lines.Text:= RequestResult;
   SG_Result.AutoSize:= false;
   FillAdvGrid(SG_Result, Cols, Rows);
   SG_Result.FixedRows:= 1;
   SG_Result.AutoSize:= true;
end;

//In CMD eingeben
// curl https://api-eu.dhl.com/track/shipments?trackingNumber=yyyyyyyyyyyyyyy -H DHL-API-Key:xxxxxxxxxxxxxxxxx -v

end.
Durch den Parameter "language" wird das Ergebnis (remark und z.T. description) auf deutsch ausgegeben.

Ich habe das Projekt mal angehängt, falls es jemand gebrauchen kann.

Vielen Dank und schönes WE
Patrick
Angehängte Dateien
Dateityp: zip Tracking.zip (2,57 MB, 0x aufgerufen)
Patrick

Geändert von Ykcim (Heute um 16:03 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 4 von 4   « Erste     234   


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 19:30 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 by Thomas Breitkreuz