Einzelnen Beitrag anzeigen

Benutzerbild von Guido R.
Guido R.

Registriert seit: 5. Jul 2007
137 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: PHP-Array als REST-Parameter

  Alt 4. Feb 2019, 16:51
Hallo TiGü !

Vielen Dank für Deine schnelle Antwort.
Also wird die Information als als JSON an tRestRequest übergeben. Daran hatte ich mich bereits versucht -
Leider werden meine Anfragen völlig ignoriert.

Ich habe in der DB genau eine Bestellung und diese hat als customerId den Wert 1.
Obwohl ich mit dem u.a. Aufruf eigentlich nur die Bestellungen mit einer customerId 3 Abrufen möchte (und somit eine leere Liste erwarte), wird mir trotzdem die ganze (1 Datensatz) Liste mit der Bestellung mit customerId 1 zurück gegeben.

Delphi-Quellcode:
procedure TDMod.DLOrdersActionExecute(Sender: TObject);
var JObj : tJSONObject;
    JAry : tJSONArray;
    Param : TRESTRequestParameter;
begin
 RestRequest.Resource := 'orders';
 JAry := tJSONArray.Create;
 JObj := tJSONObject.Create;
 JObj.AddPair('property','customerId');
 JObj.AddPair('expression','=');
 JObj.AddPair('value',tJSONNumber.Create(3));
 JAry.Add(JObj);
 RestRequest.Params.Clear;
 Param := RestRequest.Params.AddItem;
 Param.Name := 'filter';
 Param.Kind := TRESTRequestParameterKind.pkGETorPOST;
 Param.Options := Param.Options + [TRESTRequestParameterOption.poPHPArray];
 Param.Value := JAry.ToJSON;
 RestRequest.Execute;
 if RestResponse.StatusCode=200
  then begin
        ShowMessage(IntToStr(OrdersMemTable.RecordCount));
       end;
end;
Hast Du irgendeine Idee, was ich übersehen haben könnte ?

Ich hab's auch mit dem RestDebugger probiert :
Parameter [GET/POST] filter=[{"property":"customerId","expression":"=","value": 3}]
Mit und ohne Expression....
... dafür immer ohne Erfolg.
  Mit Zitat antworten Zitat