cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
Showing results for 
Search instead for 
Did you mean: 

Community Tip - Learn all about the Community Ranking System, a fun gamification element of the PTC Community. X

[POST request] Client got end of stream

Clement_D
10-Marble

[POST request] Client got end of stream

I want to send sensor value from a arduino mega to Thingworx.
I have a thing and a service created however I got an Client got end of stream when I execute my processing program.When I am using HTTPIE (that I have found on REST API tutorial) to make a single post request it is working however when i use my processing program. I am not able to make it work.
Is there conditions to make multiple post request each time I get my data ?


Is there a way to see what happen on thingworx when I make a POST request ? Thanks in advance

I have follow this tutorial.
https://eacpds.com/thingworx-using-an-arduino-uno-and-serial-connection/

My code :

import http.requests.*;
import processing.net.*; //librarie for post request to the server
import processing.serial.*; //serial connexion to arduino
//import java.net.SocketException; //add for client end of stream (socket)

Client myClient;                     // Client object

Serial myPort;                       // The serial port

final int SENSORCOUNT = 12;           // This value must match SENSORCOUNT in your Arduino Code

String sensorValues[] = new String[SENSORCOUNT];
String junk;
String beginString = "begin";
//String myServer = "localhost";
String myServer = "127.0.0.1";//server IP, warning don't put port number here
String appKey = "xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"; // xxxx are remplace in my code by my application key for admin that you have created on thingworx
String thingName = "myArduinoThing";
String serviceName = "myArduinoService";
String myURI = "http -v -j POST :8080/Thingworx/Things/" + thingName + "/Services/" + serviceName + " appKey:" + appKey;
//meme erreur 
//String myURI = "POST/Thingworx/Things/" + thingName + "/Services/" + serviceName + " appKey:" + appKey;
String myHost = "Host: " + myServer;
//String myContent = "Content-type: text/html\n"; we need to send json type
String myContent = "Content-type: application/json\n";
String sensorNames[] = {
  "value1", "value2", "value3", "value4", "value5", "value6", "value7", "value8", "value9", "value10", "value11", "value12"
};  //Enter your variable names (these must match the inputs in your Service)

void setup() {

  // Print a list of the serial ports, for debugging purposes:
  println(Serial.list());

  String portName = Serial.list()[0];
  myPort = new Serial(this, portName, 9600);
  //myPort = new Serial(this, "COM14", 9600); //Port number for serial to arduino

  myClient = new Client(this, myServer, 8080);
  print("my client: ",myClient);
}

int idx = SENSORCOUNT + 2;

void draw() {

  if (myPort.available() > 0)
  {
    junk = null;
    junk = myPort.readStringUntil('\n');

    // look for the initial “begin” string that Arduino sends
    if (junk != null)
    { 
      if (beginString.equals(trim(junk)))
      {
        junk = null;
        idx=0;
      }
    }
    
    //Read each sensor value
    if ((junk != null) && (idx < SENSORCOUNT))
    {
      sensorValues[idx] = junk;
      junk = null;
      idx++;
    }

    //When all sensor values have been read, send the info to ThingWorx
    if (idx == SENSORCOUNT)
    {
      // myURI=trim(myURI);// ajout
      print("my URI : ",myURI);
      myClient.write(myURI);

      for (int index = 0; index < SENSORCOUNT; index++)
      {
        //myClient.write("" + sensorNames[index] + "=" + trim(sensorValues[index] + " "));
        myClient.write(sensorNames[index] + "=" + trim(sensorValues[index])+"");
      }
     
      //myClient.write(" HTTP/1.1\r\n");
      print("send http");
      myClient.write(myHost + "\r\n");
      myClient.write(myContent + "\r\n");

      println("Sending this REST call:");
      print(myURI);
      for (int index = 0; index < SENSORCOUNT; index++)
      {
        print(" " + sensorNames[index] + "=" + trim(sensorValues[index] + " "));
      }
      print(" HTTP/1.1\n");
      print(myHost + '\n');
      print(myContent + '\n');
      print('\n');

      idx = SENSORCOUNT + 2;
    }
  }
}

 

5 REPLIES 5
PaiChung
22-Sapphire I
(To:Clement_D)

Have you tried looking at the application log and adding some logger statements to the services you are calling to help with the troubleshooting?

Yes, I am looking for some help to troubleshoot my POST request.

I am new to API and post request.
When I check my application log I have only log about my thingworx metrics that i have used for some test but I no longer need it.
Is there a way to see all the request POST that happen on my server ? I didn't find how I sould use logger. Is this something I had to put on my service in the javascript code ?
Thanks


log_application.JPG

 

When I add logger.info(); on my code I have this error :

Error executing service myArduinoService. Message :: La méthode 'ch.qos.logback.classic.Logger.info()' est introuvable - See Script Error Log for more details.

Is there a way to enable the logger ? Or is there an error on my code.

PaiChung
22-Sapphire I
(To:Clement_D)

Are you putting this in the Thingworx service?

I'm not familiar with the edge agent code so I'm not sure how to enable that.

 

I wasn't very clear the code that I posted is for my API on processing.
And I try to put the logger on my service code below.

 

 

me.value1=parseFloat(value1);
me.value2=parseFloat(value2);
me.value3=parseFloat(value3);
me.value4=parseFloat(value4);
me.value5=parseFloat(value5);
me.value6=parseFloat(value6);
me.value7=parseFloat(value7);
me.value8=parseFloat(value8);
me.value9=parseFloat(value9);
me.value10=parseFloat(value10);
me.value11=parseFloat(value11);
me.value12=parseFloat(value12);
logger.info(); var result = me.value1+me.value2+me.value3+me.value4+me.value5+me.value6+me.value7+me.value8+me.value9+me.value10+me.value11+me.value12 ;

 

Announcements


Top Tags