Der Funktionsbaustein wird gestartet, indem die Variable bPost im Hauptprogramm auf TRUE gesetzt wird.
Die steigende Flanke wird dann verwendet, um eine POST-Anfrage mit dem Funktionsbaustein IotHttpRequest zu senden.
Nachdem die Anfrage abgeschlossen ist, wird die Fehlerbehandlung durchlaufen. Wenn weder der Funktionsbaustein selbst noch der HTTP-Statuscode einen Fehler aufweisen, wird die JSON-Antwort vom Webserver geparst. Die JSON-Antwort enthält die Variable nReqCount, die an den Webserver gesendet wurde.
RisingEdge(CLK:= bSend); CASE nState OF 0: IF RisingEdge.Q THEN sContent:= UDINT_TO_STRING(nReqCount+1); IF fbRequest.SendRequest(sUri:= '/post?hello=world', fbClient:= fbClient, eRequestType:= ETcIotHttpRequestType.HTTP_POST, pContent:= ADR(sContent), nContentSize:= LEN2(ADR(sContent)), 0) THEN nState:= 1; nReqCount:= nReqCount+1; bBusy:= TRUE; bError:= FALSE; END_IF END_IF 1: IF NOT fbRequest.bBusy THEN bError:= TRUE; IF NOT fbRequest.bError THEN bGetContentResult:= fbRequest.GetContent(pContent:= ADR(sContent), nContentSize:= SIZEOF(sContent), bSetNullTermination:= TRUE); IF fbRequest.nStatusCode >= 200 AND fbRequest.nStatusCode < 300 THEN bGetJsonResult:= FALSE; jsonDoc:= fbRequest.GetJsonDomContent(fbJson); IF jsonDoc <>0 THEN bGetJsonResult:= TRUE; IF fbJson.HasMember(jsonDoc, 'data') THEN jsonVal:= fbJson.FindMember(jsonDoc, 'data'); sResultValue:= fbJson.GetString(jsonVal); IF STRING_TO_UDINT(sResultValue)= nReqCount THEN nValidResCount:= nValidResCount+1; bError:= FALSE; END_IF END_IF END_IF nResCount:= nResCount+1; END_IF END_IF nState:= 0; bBusy:= FALSE; IF bError THEN nErrCount:= nErrCount+1; END_IF END_IF END_CASE