Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Gelöst] request() - Netatmo

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    500

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    405

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    986

[Gelöst] request() - Netatmo

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascriptclimate
8 Beiträge 2 Kommentatoren 818 Aufrufe 2 Beobachtet
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • R Offline
    R Offline
    RKBroker
    schrieb am zuletzt editiert von RKBroker
    #1

    Guten Morgen Zusammen,

    Bin am Verzweifeln und verstehe gerade so einiges nicht mehr....
    Bei folgendem vereinfachtem Skript wird der request () in Zeile 18 mal eben locker übersprungen und bei Zeile 29 weiter gemacht. Beim zweiten Durchlauf wird der request dann ausgeführt. Aber warum ist das so? Dachte bis heute, dass die Zeilen sequenziell abgearbeitet werden.

    var access_token;
    
    function readToken() {
    
        var headers = {
            'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
        };
    
        var dataString = 'grant_type=password&client_id=5de0cc77a11ec5960911ffd0&client_secret=MeXp9wwdY7uAKee3MCUzFUJSLphuTIYju&username=xx.yy@zz.de&password=vergessen';
    
        var options = {
            url: 'https://api.netatmo.net/oauth2/token',
            method: 'POST',
            headers: headers,
            body: dataString
        };
    
        request(options, function (error, response, body) {
            if (!error && response.statusCode == 200 ) {
                var obj = JSON.parse(body, function (key, value){
                    if (key == "access_token") {
                    access_token = value;
                    return value;
                    }
                });
            };
        });
    
        var request_daten = require('request');
        var dataString_2;
    
        var lat_ne = "50.805642";
        var lon_ne = "6.977646";
        var lat_sw = "-50.803309";
        var lon_sw = "-6.982365";
    
        dataString_2 = 'access_token=' + access_token + '&lat_ne=' + lat_ne + '&lon_ne=' + lon_ne + '&lat_sw=' + lat_sw + '&lon_sw=' + lon_sw;
    }
    
    setTimeout(readToken, 1500);
    

    Eine Idee warum das so ist oder was nicht richtig ist?

    Vielen Dank und Gruß
    Rüdiger

    H 1 Antwort Letzte Antwort
    0
    • R RKBroker

      Guten Morgen Zusammen,

      Bin am Verzweifeln und verstehe gerade so einiges nicht mehr....
      Bei folgendem vereinfachtem Skript wird der request () in Zeile 18 mal eben locker übersprungen und bei Zeile 29 weiter gemacht. Beim zweiten Durchlauf wird der request dann ausgeführt. Aber warum ist das so? Dachte bis heute, dass die Zeilen sequenziell abgearbeitet werden.

      var access_token;
      
      function readToken() {
      
          var headers = {
              'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
          };
      
          var dataString = 'grant_type=password&client_id=5de0cc77a11ec5960911ffd0&client_secret=MeXp9wwdY7uAKee3MCUzFUJSLphuTIYju&username=xx.yy@zz.de&password=vergessen';
      
          var options = {
              url: 'https://api.netatmo.net/oauth2/token',
              method: 'POST',
              headers: headers,
              body: dataString
          };
      
          request(options, function (error, response, body) {
              if (!error && response.statusCode == 200 ) {
                  var obj = JSON.parse(body, function (key, value){
                      if (key == "access_token") {
                      access_token = value;
                      return value;
                      }
                  });
              };
          });
      
          var request_daten = require('request');
          var dataString_2;
      
          var lat_ne = "50.805642";
          var lon_ne = "6.977646";
          var lat_sw = "-50.803309";
          var lon_sw = "-6.982365";
      
          dataString_2 = 'access_token=' + access_token + '&lat_ne=' + lat_ne + '&lon_ne=' + lon_ne + '&lat_sw=' + lat_sw + '&lon_sw=' + lon_sw;
      }
      
      setTimeout(readToken, 1500);
      

      Eine Idee warum das so ist oder was nicht richtig ist?

      Vielen Dank und Gruß
      Rüdiger

      H Offline
      H Offline
      homecineplexx
      schrieb am zuletzt editiert von
      #2

      @RKBroker said in request() - Netatmo:

      Guten Morgen Zusammen,

      Bin am Verzweifeln und verstehe gerade so einiges nicht mehr....
      Bei folgendem vereinfachtem Skript wird der request () in Zeile 18 mal eben locker übersprungen und bei Zeile 29 weiter gemacht. Beim zweiten Durchlauf wird der request dann ausgeführt. Aber warum ist das so? Dachte bis heute, dass die Zeilen sequenziell abgearbeitet werden.

      var access_token;
      
      function readToken() {
      
          var headers = {
              'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
          };
      
          var dataString = 'grant_type=password&client_id=5de0cc77a11ec5960911ffd0&client_secret=MeXp9wwdY7uAKee3MCUzFUJSLphuTIYju&username=xx.yy@zz.de&password=vergessen';
      
          var options = {
              url: 'https://api.netatmo.net/oauth2/token',
              method: 'POST',
              headers: headers,
              body: dataString
          };
      
          request(options, function (error, response, body) {
              if (!error && response.statusCode == 200 ) {
                  var obj = JSON.parse(body, function (key, value){
                      if (key == "access_token") {
                      access_token = value;
                      return value;
                      }
                  });
              };
          });
      
          var request_daten = require('request');
          var dataString_2;
      
          var lat_ne = "50.805642";
          var lon_ne = "6.977646";
          var lat_sw = "-50.803309";
          var lon_sw = "-6.982365";
      
          dataString_2 = 'access_token=' + access_token + '&lat_ne=' + lat_ne + '&lon_ne=' + lon_ne + '&lat_sw=' + lat_sw + '&lon_sw=' + lon_sw;
      }
      
      setTimeout(readToken, 1500);
      

      Eine Idee warum das so ist oder was nicht richtig ist?

      Vielen Dank und Gruß
      Rüdiger

      also eigentlich definiert man den die variable (require) davor, bevor man sie benutzt. vor allem, wir dein request_daten überhaupt irgendwo verwendet?

      var request = require('request');
      
      request(options, function (error, response, body) {
         // blabla
      });
      
      R 1 Antwort Letzte Antwort
      0
      • H homecineplexx

        @RKBroker said in request() - Netatmo:

        Guten Morgen Zusammen,

        Bin am Verzweifeln und verstehe gerade so einiges nicht mehr....
        Bei folgendem vereinfachtem Skript wird der request () in Zeile 18 mal eben locker übersprungen und bei Zeile 29 weiter gemacht. Beim zweiten Durchlauf wird der request dann ausgeführt. Aber warum ist das so? Dachte bis heute, dass die Zeilen sequenziell abgearbeitet werden.

        var access_token;
        
        function readToken() {
        
            var headers = {
                'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
            };
        
            var dataString = 'grant_type=password&client_id=5de0cc77a11ec5960911ffd0&client_secret=MeXp9wwdY7uAKee3MCUzFUJSLphuTIYju&username=xx.yy@zz.de&password=vergessen';
        
            var options = {
                url: 'https://api.netatmo.net/oauth2/token',
                method: 'POST',
                headers: headers,
                body: dataString
            };
        
            request(options, function (error, response, body) {
                if (!error && response.statusCode == 200 ) {
                    var obj = JSON.parse(body, function (key, value){
                        if (key == "access_token") {
                        access_token = value;
                        return value;
                        }
                    });
                };
            });
        
            var request_daten = require('request');
            var dataString_2;
        
            var lat_ne = "50.805642";
            var lon_ne = "6.977646";
            var lat_sw = "-50.803309";
            var lon_sw = "-6.982365";
        
            dataString_2 = 'access_token=' + access_token + '&lat_ne=' + lat_ne + '&lon_ne=' + lon_ne + '&lat_sw=' + lat_sw + '&lon_sw=' + lon_sw;
        }
        
        setTimeout(readToken, 1500);
        

        Eine Idee warum das so ist oder was nicht richtig ist?

        Vielen Dank und Gruß
        Rüdiger

        also eigentlich definiert man den die variable (require) davor, bevor man sie benutzt. vor allem, wir dein request_daten überhaupt irgendwo verwendet?

        var request = require('request');
        
        request(options, function (error, response, body) {
           // blabla
        });
        
        R Offline
        R Offline
        RKBroker
        schrieb am zuletzt editiert von
        #3

        @homecineplexx Vielen Dank. Den Teil mit request_daten habe ich nur entfernt, um das Skript hier kurz zu halten. Die Variable hatte ich mal definiert, aber laut Forum ist das für genau diesen Fall nicht mehr notwendig. Aber auch dann wird der request übersprungen.

        Gruß

        Rüdiger

        H 1 Antwort Letzte Antwort
        0
        • R RKBroker

          @homecineplexx Vielen Dank. Den Teil mit request_daten habe ich nur entfernt, um das Skript hier kurz zu halten. Die Variable hatte ich mal definiert, aber laut Forum ist das für genau diesen Fall nicht mehr notwendig. Aber auch dann wird der request übersprungen.

          Gruß

          Rüdiger

          H Offline
          H Offline
          homecineplexx
          schrieb am zuletzt editiert von
          #4

          @RKBroker said in request() - Netatmo:

          @homecineplexx Vielen Dank. Den Teil mit request_daten habe ich nur entfernt, um das Skript hier kurz zu halten. Die Variable hatte ich mal definiert, aber laut Forum ist das für genau diesen Fall nicht mehr notwendig. Aber auch dann wird der request übersprungen.

          Gruß

          Rüdiger

          ist request nicht ein asynchroner Job/Befehl ?

          R 1 Antwort Letzte Antwort
          0
          • H homecineplexx

            @RKBroker said in request() - Netatmo:

            @homecineplexx Vielen Dank. Den Teil mit request_daten habe ich nur entfernt, um das Skript hier kurz zu halten. Die Variable hatte ich mal definiert, aber laut Forum ist das für genau diesen Fall nicht mehr notwendig. Aber auch dann wird der request übersprungen.

            Gruß

            Rüdiger

            ist request nicht ein asynchroner Job/Befehl ?

            R Offline
            R Offline
            RKBroker
            schrieb am zuletzt editiert von
            #5

            @homecineplexx Absolut keine Ahnung, ob das asynchroner Befehl ist oder nicht.
            Durch eine Menge von console.log konnte ich nur sehen, dass beim ersten Durchlauf der erste request nicht abegarbeitet bzw. aufgerufen wird. Der zweite request wird beim ersten Durlauch abegarbeitet, rennt dann aber gegen die Wand, weil das Ergbnis (sprich, den Token) vom ersten request benötigt wird...

            H 1 Antwort Letzte Antwort
            0
            • R RKBroker

              @homecineplexx Absolut keine Ahnung, ob das asynchroner Befehl ist oder nicht.
              Durch eine Menge von console.log konnte ich nur sehen, dass beim ersten Durchlauf der erste request nicht abegarbeitet bzw. aufgerufen wird. Der zweite request wird beim ersten Durlauch abegarbeitet, rennt dann aber gegen die Wand, weil das Ergbnis (sprich, den Token) vom ersten request benötigt wird...

              H Offline
              H Offline
              homecineplexx
              schrieb am zuletzt editiert von
              #6

              @RKBroker das war eigentlich eher als feststellung gemeint. darum hat der request ja auch eine callback function

              R 1 Antwort Letzte Antwort
              0
              • H homecineplexx

                @RKBroker das war eigentlich eher als feststellung gemeint. darum hat der request ja auch eine callback function

                R Offline
                R Offline
                RKBroker
                schrieb am zuletzt editiert von
                #7

                @homecineplexx NoP
                Mal "bildlich" dargestellt:

                   console.log("Request-1 Token");
                
                   request(options, function (error, response, body) {
                       console.log("Request-2 Token");
                       
                       if (!error && response.statusCode == 200 ) {
                           console.log("Request-3 Token");
                           var obj = JSON.parse(body, function (key, value){
                               console.log("Request-4 Token");
                               if (key == "access_token") {
                               console.log("Request-5 Token");
                               access_token = value;
                               return value;
                               }
                           console.log("Request-6 Token");
                           });
                       console.log("Request-7 Token");
                       };
                       
                   console.log("Read-Token-8: " + access_token);
                
                   });
                   console.log("Request-9 Token");
                       
                   var request_daten = require('request');
                   var dataString_2;
                

                Ergibt im log:

                11:04:34.242	info	javascript.0 Start javascript script.js.common.OpenWeatherUV.NetAtMo_02
                11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Request-1 Token
                11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Request-9 Token
                11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Data: undefined
                

                Demnach wird der request nicht beachtet...

                R 1 Antwort Letzte Antwort
                0
                • R RKBroker

                  @homecineplexx NoP
                  Mal "bildlich" dargestellt:

                     console.log("Request-1 Token");
                  
                     request(options, function (error, response, body) {
                         console.log("Request-2 Token");
                         
                         if (!error && response.statusCode == 200 ) {
                             console.log("Request-3 Token");
                             var obj = JSON.parse(body, function (key, value){
                                 console.log("Request-4 Token");
                                 if (key == "access_token") {
                                 console.log("Request-5 Token");
                                 access_token = value;
                                 return value;
                                 }
                             console.log("Request-6 Token");
                             });
                         console.log("Request-7 Token");
                         };
                         
                     console.log("Read-Token-8: " + access_token);
                  
                     });
                     console.log("Request-9 Token");
                         
                     var request_daten = require('request');
                     var dataString_2;
                  

                  Ergibt im log:

                  11:04:34.242	info	javascript.0 Start javascript script.js.common.OpenWeatherUV.NetAtMo_02
                  11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Request-1 Token
                  11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Request-9 Token
                  11:04:34.243	info	javascript.0 script.js.common.OpenWeatherUV.NetAtMo_02: Data: undefined
                  

                  Demnach wird der request nicht beachtet...

                  R Offline
                  R Offline
                  RKBroker
                  schrieb am zuletzt editiert von RKBroker
                  #8

                  Ok, Problem gelöst, dafür ein paar Andere :-(

                  1 Antwort Letzte Antwort
                  0

                  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
                  Antworten
                  • In einem neuen Thema antworten
                  Anmelden zum Antworten
                  • Älteste zuerst
                  • Neuste zuerst
                  • Meiste Stimmen


                  Support us

                  ioBroker
                  Community Adapters
                  Donate

                  471

                  Online

                  32.8k

                  Benutzer

                  82.9k

                  Themen

                  1.3m

                  Beiträge
                  Community
                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                  ioBroker Community 2014-2025
                  logo
                  • Anmelden

                  • Du hast noch kein Konto? Registrieren

                  • Anmelden oder registrieren, um zu suchen
                  • Erster Beitrag
                    Letzter Beitrag
                  0
                  • Home
                  • Aktuell
                  • Tags
                  • Ungelesen 0
                  • Kategorien
                  • Unreplied
                  • Beliebt
                  • GitHub
                  • Docu
                  • Hilfe