Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Js wie in "Puffer" schreiben

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.2k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    949

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

Js wie in "Puffer" schreiben

Scheduled Pinned Locked Moved Skripten / Logik
36 Posts 4 Posters 1.8k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • S Offline
    S Offline
    sveni_lee
    wrote on last edited by
    #8

    okay, aber dann müsste ich doch die strings so lange in einen Puffer schreiben bis ein LF zeichen kommt, richtig?

    oder verstehe ich an der stelle etwas falsch?

    1 Reply Last reply
    0
    • paul53P Offline
      paul53P Offline
      paul53
      wrote on last edited by
      #9

      @sveni_lee:

      okay, aber dann müsste ich doch die strings so lange in einen Puffer schreiben bis ein LF zeichen kommt, richtig? `
      So würde ich es versuchen.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      1 Reply Last reply
      0
      • S Offline
        S Offline
        sveni_lee
        wrote on last edited by
        #10

        und dann kommen wir zu meiner ursprünlichen Frage…

        wie kann ich in einen Puffer schreiben?

        1 Reply Last reply
        0
        • paul53P Offline
          paul53P Offline
          paul53
          wrote on last edited by
          #11

          Wenn es sich tatsächlich um Strings handelt, dann ist der Puffer ein String, der als Leerstring initialisiert wird, und an den man die Stringbruchstücke solange anhängt, bis ein LF enthalten ist. Der Hex-Dump zeigt allerdings etliche Steuerzeichen innerhalb der Daten.

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          1 Reply Last reply
          0
          • S Offline
            S Offline
            sveni_lee
            wrote on last edited by
            #12

            die Antworten die ich erwarte sehen dann so aus…

            NRI<response status="ok"><device id="TX-NR525"><brand>ONKYO</brand><category>AV Receiver</category><year>2013</year><model>TX-NR525</model><destination>xx</destination><firmwareversion>1060-9110-0000-</firmwareversion></device></response>
            
            1 Reply Last reply
            0
            • paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by
              #13

              @sveni_lee:

              die Antworten die ich erwarte sehen dann so aus… `
              Das ist unvollständiger XML-Code.

              NRI
               <response status="ok"><device id="TX-NR525"><brand>ONKYO</brand>
              		<category>AV Receiver</category>
              		<year>2013</year>
              		<model>TX-NR525</model>
              		<destination>xx</destination>
              		<firmwareversion>1060-9110-0000-</firmwareversion></device></response> 
              

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              1 Reply Last reply
              0
              • S Offline
                S Offline
                sveni_lee
                wrote on last edited by
                #14

                richtig… das Problem ist das der xml code in teilen gesendet wird und nicht vollständig übergeben wird...

                ~~![](</s><URL url=)https://i.imgur.com/LFkxKiN.jpg" />

                ~~![](</s><URL url=)https://i.imgur.com/qLyVEPv.jpg" />

                der komplette xml-code setzt sich den Paketen 920,921,922,923 und 924 zusammen…

                darum möchte ich die enzelnen Teile wieder zusammensetzen um den kompletten und brauchbaren xml code zu bekommen...~~~~

                1 Reply Last reply
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  wrote on last edited by
                  #15

                  Das Packet 920 enthält einen Header, der mit "!1NRI" endet. Haben die anderen Packete auch diesen Header ? Der müsste dann erst ausgefiltert werden, bevor man die XML-Teile verkettet.

                  Wie sieht das letzte Packet aus ?

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  1 Reply Last reply
                  0
                  • S Offline
                    S Offline
                    sveni_lee
                    wrote on last edited by
                    #16

                    nein, die anderen haben diesen header nicht… der isr aber wichtig für die weiterverarbeitung müsste also am Anfang des Paketes bestehen bleiben...

                    ~~![](</s><URL url=)https://i.imgur.com/sTO0PT2.jpg" />

                    ~~![](</s><URL url=)https://i.imgur.com/jryLouz.jpg" />

                    ~~![](</s><URL url=)https://i.imgur.com/E80eKKM.jpg" />

                    ![](</s><URL url=)https://i.imgur.com/YKPAKSY.jpg" />~~~~~~

                    1 Reply Last reply
                    0
                    • paul53P Offline
                      paul53P Offline
                      paul53
                      wrote on last edited by
                      #17

                      Sind das keine Header bis zum Byte 0x41 : "|" (senkrechter Strich) ? Müssten die nicht rausgefiltert werden ?

                      Wo erscheint das LF ?

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      1 Reply Last reply
                      0
                      • S Offline
                        S Offline
                        sveni_lee
                        wrote on last edited by
                        #18

                        das ist richtig…

                        ~~![](</s><URL url=)https://i.imgur.com/SaV0DU6.jpg" />

                        Wireshark sagt mir das der "Datenteil" immer erst mit byte 66 startet…

                        ![](</s><URL url=)https://i.imgur.com/wzzsRhF.jpg" />~~

                        1 Reply Last reply
                        0
                        • paul53P Offline
                          paul53P Offline
                          paul53
                          wrote on last edited by
                          #19

                          Werden die ersten 66 Zeichen auch an die Funktion übergeben ?

                          on('data', function (data) {
                          

                          Oder sind sie an der Stelle schon ausgefiltert ?

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          1 Reply Last reply
                          0
                          • AlCalzoneA Offline
                            AlCalzoneA Offline
                            AlCalzone
                            Developer
                            wrote on last edited by
                            #20

                            Ich gehe nicht davon aus, dass du die TCP-Header ebenfalls empfängst. Wireshark zeigt dir das gesamte Datenpaket an, das übers Netzwerk geht, Anwendungen sehen i.d.R. nur den Inhalt des TCP-Pakets (in deinem Fall vermutlich ab Byte 66).

                            Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                            1 Reply Last reply
                            0
                            • S Offline
                              S Offline
                              sveni_lee
                              wrote on last edited by
                              #21

                              die sind an der stelle schon ausgefiltert…

                              die werden hier ausgefiltert:

                              function eiscp_packet_extract(packet) {
                                  /*
                                    Exracts message from eISCP packet
                                    Strip first 18 bytes and last 3 since that's only the header and end characters
                                  */
                                  return packet.toString('ascii', 18, packet.length - 3);
                              
                              1 Reply Last reply
                              0
                              • S Offline
                                S Offline
                                sveni_lee
                                wrote on last edited by
                                #22

                                @AlCalzone:

                                Ich gehe nicht davon aus, dass du die TCP-Header ebenfalls empfängst. Wireshark zeigt dir das gesamte Datenpaket an, das übers Netzwerk geht, Anwendungen sehen i.d.R. nur den Inhalt des TCP-Pakets (in deinem Fall vermutlich ab Byte 66). `

                                dann sind das also nur die 18 bytes die noch ausgfiltert werden

                                1 Reply Last reply
                                0
                                • paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by
                                  #23

                                  Wo hast Du diesen Code her ? Ich verstehe ihn nicht :oops:

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  1 Reply Last reply
                                  0
                                  • paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by
                                    #24

                                    Hier sollen die ersten 18 Zeichen nach dem TCP-Header ausgefiltert werden, so dass das Ergebnis mit "NRI<" beginnt. Das darf aber nur beim ersten Packet erfolgen, wie die Hexdumps zeigen.

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      sveni_lee
                                      wrote on last edited by
                                      #25

                                      wenn der Onkyo daten sendet wird diese funktion aufgerufen…

                                      	on('data', function (data) {
                                      
                                      		var iscp_message = eiscp_packet_extract(data),
                                      			result = iscp_to_command(iscp_message);
                                      
                                      		result.iscp_command = iscp_message;
                                              result.host  = config.host;
                                              result.port  = config.port;
                                              result.model = config.model;
                                      
                                      		self.emit('debug', util.format("DEBUG (received_data) Received data from %s:%s - %j", config.host, config.port, result));
                                      		self.emit('data', result);
                                      
                                      		// If the command is supported we emit it as well
                                      		if (typeof result.command !== 'undefined') {
                                      			if (Array.isArray(result.command)) {
                                      				result.command.forEach(function (cmd) {
                                      					self.emit(cmd, result.argument);
                                      				});
                                      			} else {
                                      				self.emit(result.command, result.argument);
                                      			}
                                      		}
                                      	});
                                      };
                                      

                                      hier wird das "Datenpaket übergeben zum "entpacken"…

                                      var iscp_message = eiscp_packet_extract(data)
                                      

                                      und das ist dann diese Funktion

                                      function eiscp_packet_extract(packet) {
                                          /*
                                            Exracts message from eISCP packet
                                            Strip first 18 bytes and last 3 since that's only the header and end characters
                                          */
                                          return packet.toString('ascii', 18, packet.length - 3);
                                      }
                                      

                                      das ganze ist eiscp node.js… das Problem ist das der code nicht mehr gepflegt wird und bisher nicht dafür ausgelegt ist diese Daten (xml) zu verarbeiten... diese sind aber notwendig um mein Project der Steurung des Onkyo umzusetzen...

                                      1 Reply Last reply
                                      0
                                      • S Offline
                                        S Offline
                                        sveni_lee
                                        wrote on last edited by
                                        #26

                                        @paul53:

                                        Hier sollen die ersten 18 Zeichen nach dem TCP-Header ausgefiltert werden, so dass das Ergebnis mit "NRI<" beginnt. Das darf aber nur beim ersten Packet erfolgen, wie die Hexdumps zeigen. `
                                        richtig…

                                        darum möchte ich ja in einen Puffer schreiben bis das "schlußbyte" 0A kommt, dann das komplette paket übergeben...

                                        wenn nun schon ein 0A im ersten paket kommt (bei kuruen nachrichten vom Onkyo) würde es sofort übergeben...

                                        so mein Plan...

                                        1 Reply Last reply
                                        0
                                        • paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by
                                          #27

                                          @sveni_lee:

                                          das ganze ist eiscp node.js `
                                          Bist Du sicher, dass eISCP der richtige Ansatz ist ? Es wird XML-Code geliefert.
                                          @sveni_lee:

                                          darum möchte ich ja in einen Puffer schreiben bis das "schlußbyte" 0A kommt, dann das komplette paket übergeben… `
                                          Da zwischen 1. und den weiteren Packeten unterschieden werden muss (wegen der ersten 18 Byte), vielleicht folgender Ansatz

                                          var xml = ''; // Puffer
                                          var first = true; // Indikator erstes Packet
                                          
                                          on('data', function (data) {
                                             if(first) {
                                                xml = eiscp_packet_extract(data);
                                                first = false;
                                             } else {  
                                                xml = xml + data; // evtl. data.toString('utf8', 0, data.length - 3) ?
                                             }   
                                             if(xml.indexOf('\n') != -1) {
                                                first = true;
                                                ... hier die Auswertung des XML-Codes
                                             }
                                          });     
                                          
                                          

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          676

                                          Online

                                          32.6k

                                          Users

                                          82.2k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe