Obsah:
- Zásoby
- Krok 1: Protokol REST JSON Http (s)
- Krok 2: Tok
- Krok 3: Hlavný panel
- Krok 4: Tok importu (projekt, skript, atď.)
- Krok 5: Ako to všetko funguje spoločne
- Krok 6: HTTP POST a ZÍSKAJTE
- Krok 7: Uzly tlačidiel
- Krok 8: Uzol funkcie
- Krok 9: Uzol JSON a injekčný uzol
- Krok 10: Textový uzol a ladiaci uzol
- Krok 11: Uzol grafu
- Krok 12: Merací uzol a prepojovacie uzly
- Krok 13: Ďakujem, že ste si prečítali môj návod
2025 Autor: John Day | [email protected]. Naposledy zmenené: 2025-01-23 15:05
Tento návod vás naučí pracovať s JSON v node-RED. Ukážem vám, ako ovládať sieťové zásuvky pomocou prenosu súborov json prostredníctvom http get a post. A tieto znalosti môžete neskôr použiť na ovládanie akéhokoľvek zariadenia podporujúceho protokol JSON.
Na účely výučby budem používať sieťovú zásuvku NETIO 4All, ale nebojte sa, nemusíte nič kupovať. NETIO má úžasné online demo 4All, ktoré môžete použiť.
Zásoby
NETIO 4All sieťová zásuvka alebo 4All online demo:
Uzol-ČERVENÝ
Krok 1: Protokol REST JSON Http (s)
Táto časť je trochu technická, ale prosím, vydržte so mnou. Ak by som túto časť nevysvetlil, potom by ste mali problémy s porozumením hodnôt v súboroch json, ktoré budeme odosielať v uzle RED.
Akcie platné pre každý výstup (elektrická zásuvka):
Vo všetkých protokoloch M2M používajú zásuvky NETIO rovnaké akcie, aké je možné použiť na jednotlivé výstupy. Do akéhokoľvek výstupu je možné zapísať napríklad akciu Prepnúť alebo Skrátiť.
Premennú Action je však možné použiť iba na zápis hodnôt, nemožno ju použiť na čítanie aktuálneho stavu výstupu.
Toto sú akcie, ktoré môžete použiť na každý výstup:
0 = výstup vypnutý (vypnutý)
1 = výstup zapnutý (zapnutý)
2 = Výstup je krátkodobo vypnutý (krátko vypnutý)
3 = Výstup je zapnutý na krátku dobu (krátky zapnutý)
4 = Výstup prepnutý z jedného stavu do druhého (prepínač)
5 = stav výstupu nezmenený (žiadna zmena)
6 = Ignorované
Príklad - súbor JSON na prepnutie výstupu č. 1:
{
"Výstupy": [{
"ID": 1, „Akcia“: 4
}]
}
ID - toto číslo udáva, ktorý výstup budeme používať
Akcia - táto časť je akcia, ktorú výstup vykoná (napr. 1 (Zapnúť výstup))
Krok 2: Tok
A teraz hlavná časť. Takto vyzerá prostredie uzol-ČERVENÉ.
Importovali sme tok rozhrania API URL (projekt, ktorý vidíte. Neskôr vám ukážem, ako importovať toky a tento projekt) Tento projekt pozostáva z dvoch častí:
- Tok NETIO AN30 (JSON REST API)
- Hlavný panel (grafické rozhranie, pomocou ktorého môžete ovládať svoj program)
Krok 3: Hlavný panel
Takto vyzerá informačný panel v uzle-ČERVENOM pre tento pokyn. Môžete si ho prispôsobiť, ak chcete, aby vyhovoval vášmu vkusu.
Palubná doska tohto projektu je rozdelená na 4 časti:
- Stav zariadenia - zobrazuje informácie o zariadení, ako je model, adresa mac alebo verzia firmvéru.
- (POST) Ovládací výstup 1 - obsahuje 5 tlačidiel, ktorými sa ovláda výstup 1. Každé tlačidlo vykonáva inú akciu
- (GET) O1 - O4 Výstupné stavy - Táto časť zobrazuje aktuálny stav každého výstupu z vášho zariadenia.
- Správa zariadenia - V tejto časti nájdete všetky druhy grafov a meradiel, ktoré zobrazujú aktuálne namerané hodnoty zo zariadenia NETIO 4Aall
Krok 4: Tok importu (projekt, skript, atď.)
V ponuke (pravý horný roh) vyberte Importovať a potom Schránku.
Potom skopírujte text nižšie do uvedeného poľa a kliknite na položku Importovať.
Inštalácia chýbajúcich uzlov
Uzly sa načítajú do vybraného toku. Je možné, že sa zobrazí chybové hlásenie so zoznamom uzlov, ktoré sa importujú, ale ešte nie sú nainštalované v Node-RED. V tomto prípade je potrebné nainštalovať chýbajúce uzly.
Ak chýbajú uzly, v ponuke vyberte Spravovať paletu, kliknite na Inštalovať a vyhľadajte a nainštalujte uzly, ktoré vám chýbajú.
Import textu:
[{"id": "56b9510c.98c6f", "type": "tab", "label": "NETIO AN30 (REST JSON)", "disabled": false, "info": ""}, {"id ":" 6a66b637.da1558 "," type ":" http request "," z ":" 56b9510c.98c6f "," name ":" HTTP Request (POST) "," method ":" POST "," ret ": "txt", "url": "https://netio-4All.netio-products.com:8080/netio.json", "tls": "", "x": 430, "y": 100, "drôty":
Krok 5: Ako to všetko funguje spoločne
Tok je v zásade rozdelený na dve časti: POST a GET.
POST: Písanie na O1
- Na ovládacom paneli sa zobrazí päť tlačidiel vytvorených na Paneli v toku.
- Po kliknutí na tlačidlo Výstup 1 = ZAPNUTÉ na hlavnom paneli sa užitočné zaťaženie nastaví na súbor netio.json, ktorý určuje výstup a akciu (definované pre každé z tlačidiel).
- Blok POST (HTTP Request) odosiela súbor netio.json ako požiadavku na IP adresu.
- Odpoveď servera (stav) sa vráti ako výstup.
- Blok Msg.payload zobrazuje výsledok z HTTP Request (POST).
ZÍSKAJTE: Čítanie z O1 - O4
- Blok 1 sekundového opakovania aktivuje na jednu sekundu blok požiadavky HTTP (GET), ktorý zase odošle netio.json ako požiadavku GET a vráti kompletný súbor JSON so stavom soketu prijatým zo servera.
- Blok JSON Parse transformuje súbor JSON z bloku HTTP Request (GET) na objekt JSON, aby bolo možné manipulovať s vlastnosťami v súbore JSON.
- Funkčný blok preberá jednotlivé časti objektu JSON a transformuje ich na vlastnosti objektu msg na neskoršie použitie.
- Blok aktuálneho grafu nastavuje msg.payload na vlastnosť msg. TotalCurrent objektu msg, pretože nasledujúci blok aktuálneho grafu (zariadenie) môže zobrazovať iba hodnotu msg.payload.
- Nasledujú rôzne výstupné uzly, aby sa na ovládacom paneli zobrazili vybrané vlastnosti objektu msg prevzaté z objektu JSON.
Objekt msg a msg.payload
Jednoduché a výstižné vysvetlenie nájdete tu:
www.steves-internet-guide.com/node-red-mess…
Krok 6: HTTP POST a ZÍSKAJTE
HTTP požiadavka (POST)
Tento uzol odosiela príkazový súbor netio.json ako požiadavku HTTP (POST) na ovládanie zariadenia NETIO 4All.
HTTP požiadavka (GET)
Tento uzol odošle požiadavku HTTP (GET) a vráti stavovú odpoveď.
Adresa naplnená vopred ukazuje na online demo NETIO 4All, kde si môžete otestovať pripojenie bez toho, aby ste mali na stole zariadenie NETIO.
netio-4all.netio-products.com
V týchto uzloch je možné nastaviť vlastnú IP adresu; IP však treba zmeniť v uzloch HTTP Request, POST aj GET.
Krok 7: Uzly tlačidiel
Kliknutím na uzol tlačidla sa vygeneruje správa obsahujúca súbor netio.json (pravý obrázok), ktorý sa potom odošle prostredníctvom uzla http post do inteligentnej zásuvky netio.
Krok 8: Uzol funkcie
Funkčný uzol je špeciálny uzol, ktorý umožňuje napísať vlastnú funkciu JavaScript.
V tomto návode funkcia vyberie hodnoty z analyzovaného súboru JSON (teraz objekt JSON) a priradí ich k vlastnostiam objektu msg.
Kód je rozdelený do štyroch sekcií:
- Priradenie hodnôt z objektu JSON jednotlivým vlastnostiam objektu msg
- Riešenie chýb v prípade, že sieťová zásuvka nepodporuje globálne merania
Ak sieťová zásuvka nepodporuje meranie globálnych hodnôt, Node-RED by zobrazoval chyby, pretože táto funkcia by nenašla príslušnú vlastnosť, napr. msg.payload. GlobalMeasure. Voltage, pretože by nebol prítomný v objekte JSON. V tomto prípade je vlastnosť objektu msg, napr. msg. Voltage, je nastavené na 0 a chyba je zachytená a spracovaná.
- Priradenie hodnôt stavu výstupu
- Nastavenie farieb zobrazených hodnôt výstupného stavu podľa výstupných stavov
Krok 9: Uzol JSON a injekčný uzol
Uzol JSON
Uzol JSON analyzuje súbor JSON a transformuje ho na objekt JSON.
Ako odpoveď servera na požiadavku GET uzol HTTP Request vráti súbor JSON obsahujúci aktuálny stav zariadenia NETIO 4x, ale je to iba textový súbor, takže na prácu s údajmi potrebuje súbor JSON na analýzu do objektu JSON.
Injekčný uzol
Tento uzol každú sekundu aktivuje uzol požiadavky HTTP, ktorý odošle požiadavku GET.
Výsledkom je, že hodnoty na informačnom paneli sa aktualizujú v priebehu jednej sekundy
Krok 10: Textový uzol a ladiaci uzol
Textový uzol
Zobrazí textové pole na hlavnom paneli. V tomto návode textové uzly zobrazujú prúd, napätie, model, verziu firmvéru alebo verziu JSON.
Štítok sa zobrazí na hlavnom paneli a názov je názov uzla zobrazený v toku v uzle ČERVENÉ.
Ladiaci uzol
Zobrazuje msg.payload.
Krok 11: Uzol grafu
Tento uzol vykresľuje aktuálny graf na hlavnom paneli podľa hodnoty užitočného zaťaženia.
Tento uzol môže vykresľovať grafy iba podľa hodnoty užitočného zaťaženia.
Z tohto dôvodu sa uzol funkcie používa na nastavenie msg.payload na hodnotu, ktorú je potrebné zobraziť.
msg.payload = msg. TotalCurrent;
Krok 12: Merací uzol a prepojovacie uzly
Merací uzol
Tento uzol pridáva na informačný panel miniaplikáciu.
V tomto návode každý merač vizualizuje jednu vlastnosť objektu správy: napätie [V], prúd [A], frekvenciu [Hz] a celkový skutočný účinník (TPF).
Spojovacie uzly
Pripojenie a odpojenie uzlov funguje ako tunel. Správa msg.payload príde do uzla prepojenia a odíde z uzla prepojenia.
Použil som to, aby bol tok o niečo prehľadnejší a čitateľnejší.
Krok 13: Ďakujem, že ste si prečítali môj návod
Dúfam, že sa vám páčil môj návod a dúfame, že ste sa dozvedeli niečo nové.
Tento návod je iba skrátenou verziou iného sprievodcu, ktorý som vytvoril
Pôvodný sprievodca je dlhší, oveľa podrobnejšie zameraný a vo všeobecnosti lepšie štruktúrovaný. Ak niečomu nerozumiete alebo si myslíte, že som niečo zmeškal alebo dostatočne nevysvetlil, určite to tam nájdete.
Sľubujem, že nebudete sklamaní
Originál:
K dispozícii sú tiež podobné príručky o rôznych použitiach uzla-RED, takže ak vás to zaujíma, neváhajte a preskúmajte:
Práca s API REST URL v uzle-ČERVENOM
www.netio-products.com/en/application-notes/an29-node-red-example-of-url-api-communication-with-netio-4x
Práca s REST XML v uzle-ČERVENOM
www.netio-products.com/en/application-notes/an31-node-red-example-of-rest-xml-communication-with-netio-4x
Práca s TCP/Modbus v uzle-ČERVENOM
Už čoskoro:)
Odporúča:
Visuino Ako používať tlačidlo ako vstup na ovládanie vecí ako LED: 6 krokov
Visuino Ako používať tlačidlo ako vstup na ovládanie vecí ako LED: V tomto návode sa naučíme, ako zapnúť a vypnúť LED diódu jednoduchým tlačidlom a Visuino. Pozrite si ukážkové video
Ako sa pripojiť a začať pracovať so svojim DJ zariadením: 8 krokov
Ako sa pripojiť a začať pracovať s vašim DJ zariadením: Účelom tohto návodu je ukázať vám, čitateľovi, ako nastaviť gramofón a ako pripojiť DJ zariadenie
Ako pracovať s Arduinom a rôznymi RGB LED diódami: 3 kroky
Ako pracovať s Arduino a rôznymi LED diódami: Arduino je úžasné malé zariadenie. Jednou z najpoužívanejších aplikácií pre toto výkonné malé zariadenie je často blikanie alebo blikanie diódy LED. Tento tutoriál vám ukáže tri spôsoby práce s RGB LED a Arduino. Prvým spôsobom je použiť jednoduchý
Ako používať Wiimote ako počítačovú myš pomocou sviečok ako senzora !!: 3 kroky
Ako používať Wiimote ako počítačovú myš pomocou sviečok ako senzora !!: Táto príručka vám ukáže, ako prepojiť diaľkový ovládač Wii Remote (Wiimote) s počítačom a používať ho ako myš
Začíname pracovať s MpegPlayer v Rockboxe - IPod Nano 1. generácie: 7 krokov
Začíname pracovať s MpegPlayer v Rockboxe - IPod Nano 1. generácie: ** VEĽMI DÔLEŽITÉ AKTUALIZÁCIE ** Ak ste si to už predtým pozreli, WINFF zmenil svoje používateľské rozhranie. Teraz je to vo verzii 0.41. Program je teraz efektívnejší a teraz má „rockbox“; v časti „Previesť na“zoznam. Aktualizujem to, keď urobím su