NEWS
daten über REST Schnittstelle lesen
-
@ben1983 sagte: gibts da auch ein Beispiel für JS?
const url = 'http://localhost:8080/rest/1/projects'; // oder mit /.json? request(url, function(error, response, result) { if(error) log(error, 'warn'); else log(result); });Das hat er mit UND ohne Json geloggt:
(8684) script.js.common.Zyklische_Abläufe: {"project":[{"name":"EnergieMonitoring","path":"C:/GridVisProjekte/EnergieMonitoring","status":"Ready","displayStatus":"Bereit","numberOfDevices":16}]}Aber das ging ja jetzt auch ohne den RESTful API adapter.
Brauch ich den also nicht?
Ist nur die Frage, wie ich jetzt an einzelne Daten ran komme. -
Das hat er mit UND ohne Json geloggt:
(8684) script.js.common.Zyklische_Abläufe: {"project":[{"name":"EnergieMonitoring","path":"C:/GridVisProjekte/EnergieMonitoring","status":"Ready","displayStatus":"Bereit","numberOfDevices":16}]}Aber das ging ja jetzt auch ohne den RESTful API adapter.
Brauch ich den also nicht?
Ist nur die Frage, wie ich jetzt an einzelne Daten ran komme.@ben1983 sagte: Das hat er mit UND ohne Json geloggt:
Dann ist JSON offenbar Standard.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Aber das ging ja jetzt auch ohne den RESTful API adapter.
Brauch ich den also nicht?Nein, der wird nicht benötigt.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Ist nur die Frage, wie ich jetzt an einzelne Daten ran komme.
Du musst die URL erweitern, wie in der API-Doku gezeigt, z.B.
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices;sollte die 16 Geräte auflisten?
-
@ben1983 sagte: Das hat er mit UND ohne Json geloggt:
Dann ist JSON offenbar Standard.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Aber das ging ja jetzt auch ohne den RESTful API adapter.
Brauch ich den also nicht?Nein, der wird nicht benötigt.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Ist nur die Frage, wie ich jetzt an einzelne Daten ran komme.
Du musst die URL erweitern, wie in der API-Doku gezeigt, z.B.
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices;sollte die 16 Geräte auflisten?
@paul53 soweit bin ich gekommen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/online/values'das kommt zurück:
(8684) script.js.common.Zyklische_Abläufe: {"valuetype":[{"value":"PowerActive","typeName":"L1","type":"L1","unit":"W","valueName":"Wirkleistung"},{"value":"PowerActive","typeName":"L2","type":"L2","uaber ich raffe es von der DOku her einfach nicht, wie ich an die Daten komme
-
@paul53 soweit bin ich gekommen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/online/values'das kommt zurück:
(8684) script.js.common.Zyklische_Abläufe: {"valuetype":[{"value":"PowerActive","typeName":"L1","type":"L1","unit":"W","valueName":"Wirkleistung"},{"value":"PowerActive","typeName":"L2","type":"L2","uaber ich raffe es von der DOku her einfach nicht, wie ich an die Daten komme
-
@ben1983
Was ergibt?const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues';@paul53 said in daten über REST Schnittstelle lesen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues';
ergebnis:
8684) script.js.common.Zyklische_Abläufe: no online values found. Please refer to the documentation.Also er gibt mir ja schon zurück, welche Werte zur Verfügung stehen, aber leider schnalle ich nun nicht, was ich noch hinzufügen muss, um an die werte zu kommen.
-
@paul53 said in daten über REST Schnittstelle lesen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues';
ergebnis:
8684) script.js.common.Zyklische_Abläufe: no online values found. Please refer to the documentation.Also er gibt mir ja schon zurück, welche Werte zur Verfügung stehen, aber leider schnalle ich nun nicht, was ich noch hinzufügen muss, um an die werte zu kommen.
-
@ben1983
Versuche mal:const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;L1,L2,L3';@paul53 said in daten über REST Schnittstelle lesen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues&value=45;PowerActive;L1';
das geht gar nicht:
684) script.js.common.Zyklische_Abläufe: <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/> <title>Error 404 Not Found</title> </head> <body><h2>HTTP ERROR 404 Not Fou -
@paul53 said in daten über REST Schnittstelle lesen:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues&value=45;PowerActive;L1';
das geht gar nicht:
684) script.js.common.Zyklische_Abläufe: <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/> <title>Error 404 Not Found</title> </head> <body><h2>HTTP ERROR 404 Not Fou -
@ben1983 sagte in daten über REST Schnittstelle lesen:
das geht gar nicht:
Sorry, anstelle von & muss eine Fragezeichen hin (habe oben korrigiert).
@paul53 das kam raus:
8684) script.js.common.Zyklische_Abläufe: {"value":{"45.PowerActive.L1":"NaN","45.PowerActive.L2":"NaN","45.PowerActive.L3":"NaN"},"time":{"45.PowerActive.L1":1622732136207000000,"45.PowerActive.L2":wir scheinen uns zu nähern
-
@ben1983 sagte in daten über REST Schnittstelle lesen:
das geht gar nicht:
Sorry, anstelle von & muss eine Fragezeichen hin (habe oben korrigiert).
@paul53 habe es jetzt so versucht:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13';Das kam zurück:
javascript.0 2021-06-03 17:00:49.384 info (8684) script.js.common.Zyklische_Abläufe: {"value":{"45.PowerActive.SUM13":250.13656616210938},"time":{"45.PowerActive.SUM13":1622732449198000000},"valueType":{}}Sieht gut aus, aber wie komme ich jetzt an den wert? in dfem fall 250.....
-
@paul53 habe es jetzt so versucht:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13';Das kam zurück:
javascript.0 2021-06-03 17:00:49.384 info (8684) script.js.common.Zyklische_Abläufe: {"value":{"45.PowerActive.SUM13":250.13656616210938},"time":{"45.PowerActive.SUM13":1622732449198000000},"valueType":{}}Sieht gut aus, aber wie komme ich jetzt an den wert? in dfem fall 250.....
@ben1983 sagte: wie komme ich jetzt an den wert? in dfem fall 250
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13'; request(url, function(error, response, result) { if(error) log(error, 'warn'); else { let value = JSON.parse(result).value; log('Wirkleistung: ' + value['45.PowerActive.SUM13']); } }); -
@ben1983 sagte: wie komme ich jetzt an den wert? in dfem fall 250
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13'; request(url, function(error, response, result) { if(error) log(error, 'warn'); else { let value = JSON.parse(result).value; log('Wirkleistung: ' + value['45.PowerActive.SUM13']); } }); -
@ben1983 sagte: wie komme ich jetzt an den wert? in dfem fall 250
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13'; request(url, function(error, response, result) { if(error) log(error, 'warn'); else { let value = JSON.parse(result).value; log('Wirkleistung: ' + value['45.PowerActive.SUM13']); } }); -
@paul53 Kannst DU mir noch sagen, wie Du in der Doku darauf gekommen bist?
Falls ich später noch sowas wie historische Daten auslesen will, kann ich es darauf adaptieren.
Also ich habe die Zusammensetzung der werte nicht gefunden in der Doku.
-
@paul53 Würde mir gerne hierzu ne Struktur erstellen,
Welche Folgendes enthält:
DeviceId
Parameter 1,Parameter2....
IDParameter1,IdParameter2...Geht das vielleicht irgendwie so:
Let Device = { „ID“: 45, „Parameter“:[„abc“,“def“],“IdPara“:[„a“,“b“]};???
-
@paul53 Würde mir gerne hierzu ne Struktur erstellen,
Welche Folgendes enthält:
DeviceId
Parameter 1,Parameter2....
IDParameter1,IdParameter2...Geht das vielleicht irgendwie so:
Let Device = { „ID“: 45, „Parameter“:[„abc“,“def“],“IdPara“:[„a“,“b“]};???
-
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
-
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
@paul53 Habe es jetzt so realisiert, funktioniert top.
let Device = []; let i = 0; // Talstraße 1A Messgruppe 1 Device[i] = {'ID':'27','Value':[{"Name":"PowerActive","Type":"SUM13","InternalId":IdWirkleistungGesamt}]}; i = i + 1; // Talstraße 1A Messgruppe 2 Device[i] = {'ID':'28','Value':[{"Name":"PowerActive","Type":"Input05","InternalId":IdWirkleistungGarageII}, {"Name":"PowerActive","Type":"Input06","InternalId":IdWirkleistungPv}, {"Name":"PowerActive","Type":"Input07","InternalId":IdWirkleistungGarageI}, {"Name":"PowerActive","Type":"Input08","InternalId":IdWirkleistungAussensteckdosen}]}; i = i + 1; Device.forEach(function (MyDevice) { let DeviceID = MyDevice.ID; MyDevice.Value.forEach(function (MyValue) { const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=' + DeviceID + ';' + MyValue.Name + ';' + MyValue.Type; request(url, function(error, response, result) { if(error) { log(error, 'warn'); } else { let value = JSON.parse(result).value; value = Math.round(value[DeviceID + '.' + MyValue.Name + '.' + MyValue.Type]); setState(MyValue.InternalId,value); } }); }); }); -
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden
