Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Einsteigerfragen
  4. POST requests bei der Adapter Entwicklung

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.6k

POST requests bei der Adapter Entwicklung

Geplant Angeheftet Gesperrt Verschoben Einsteigerfragen
4 Beiträge 2 Kommentatoren 401 Aufrufe 2 Watching
  • Ä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.
  • L Offline
    L Offline
    lonestar2001
    schrieb am zuletzt editiert von
    #1

    Ich bin leider blutiger Anfänger bei der Adapter-Entwicklung und habe daher sehr grundlegende Fragen:

    Ich möchte per https POST-request einen "username" und "password" (gehashed) an eine URL schicken. Aktuell verwende ich dafür Axios.

    1. Was muss ich tun, damit ich das Passwort nicht im Klartext sondern gehashed übermittel? Ich habe dazu nichts gefunden. In dem Pyhton3 Code, den ich Portieren möchte für ioBroker wird die die hashlib verwendet und das Passwort folgendermaßen verschlüsselt:
    passwordHashed = hashlib.sha1(password.encode()).hexdigest()
    
    1. Die URL, die ich versuche zu erreichen ist die "https://www.myidm.at/api/user/login". Hier bekomme ich mit dem folgenden Code allerdings immer ein "AxiosError: Request failed with status code 404". Die baseURL ist allerdings erreichbar. Liegt es an den Headern?
            this.idmApiClient = axios.create({
                baseURL: 'https://www.myidm.at',
                timeout: 1000,
                headers: {
                    'User-Agent': 'IDM App (Android)'
                },
                data: {
                    username: this.config.clientLogin, 
                    password: 'abc'
                },
                responseType: 'json',
                responseEncoding: 'utf8',
                httpsAgent: new https.Agent({
                    rejectUnauthorized: false,
                })
            });
    
            try {
                const installations = await this.idmApiClient.post('/api/user/login');
                this.log.info('Successfully returning Installation repsonse');
                this.log.debug(`response: ${installations.status}: ${JSON.stringify(installations.data)}`);
            } catch (err) {
                this.log.error(err);
                // AxiosError: Request failed with status code 404
            }
    

    Für jeden Suchbegriff, den ihr mir nennen könnt bin ich sehr dankbar

    arteckA 1 Antwort Letzte Antwort
    0
    • L lonestar2001

      Ich bin leider blutiger Anfänger bei der Adapter-Entwicklung und habe daher sehr grundlegende Fragen:

      Ich möchte per https POST-request einen "username" und "password" (gehashed) an eine URL schicken. Aktuell verwende ich dafür Axios.

      1. Was muss ich tun, damit ich das Passwort nicht im Klartext sondern gehashed übermittel? Ich habe dazu nichts gefunden. In dem Pyhton3 Code, den ich Portieren möchte für ioBroker wird die die hashlib verwendet und das Passwort folgendermaßen verschlüsselt:
      passwordHashed = hashlib.sha1(password.encode()).hexdigest()
      
      1. Die URL, die ich versuche zu erreichen ist die "https://www.myidm.at/api/user/login". Hier bekomme ich mit dem folgenden Code allerdings immer ein "AxiosError: Request failed with status code 404". Die baseURL ist allerdings erreichbar. Liegt es an den Headern?
              this.idmApiClient = axios.create({
                  baseURL: 'https://www.myidm.at',
                  timeout: 1000,
                  headers: {
                      'User-Agent': 'IDM App (Android)'
                  },
                  data: {
                      username: this.config.clientLogin, 
                      password: 'abc'
                  },
                  responseType: 'json',
                  responseEncoding: 'utf8',
                  httpsAgent: new https.Agent({
                      rejectUnauthorized: false,
                  })
              });
      
              try {
                  const installations = await this.idmApiClient.post('/api/user/login');
                  this.log.info('Successfully returning Installation repsonse');
                  this.log.debug(`response: ${installations.status}: ${JSON.stringify(installations.data)}`);
              } catch (err) {
                  this.log.error(err);
                  // AxiosError: Request failed with status code 404
              }
      

      Für jeden Suchbegriff, den ihr mir nennen könnt bin ich sehr dankbar

      arteckA Offline
      arteckA Offline
      arteck
      Developer Most Active
      schrieb am zuletzt editiert von arteck
      #2

      @lonestar2001
      mit der funktion

      const md5 = require('md5');
      
      md5(dein password)
      

      zigbee hab ich, zwave auch, nuc's genauso und HA auch

      L 1 Antwort Letzte Antwort
      0
      • arteckA arteck

        @lonestar2001
        mit der funktion

        const md5 = require('md5');
        
        md5(dein password)
        
        L Offline
        L Offline
        lonestar2001
        schrieb am zuletzt editiert von
        #3

        @arteck

        Danke für den Tipp, ich hab es jetzt folgendermaßen gelöst:

        const { createHash, Hash } = require('crypto');
        
        const hash = createHash('sha1');
        const myData = 'Password';
        hash.update(myData);
        this.log.debug('Hash: '+hash.digest('hex'));
        

        Leider kommt mein POST-request nach wie vor nicht durch.
        Die API vom Server ist auch alles andere als hilfreich

        L 1 Antwort Letzte Antwort
        0
        • L lonestar2001

          @arteck

          Danke für den Tipp, ich hab es jetzt folgendermaßen gelöst:

          const { createHash, Hash } = require('crypto');
          
          const hash = createHash('sha1');
          const myData = 'Password';
          hash.update(myData);
          this.log.debug('Hash: '+hash.digest('hex'));
          

          Leider kommt mein POST-request nach wie vor nicht durch.
          Die API vom Server ist auch alles andere als hilfreich

          L Offline
          L Offline
          lonestar2001
          schrieb am zuletzt editiert von
          #4

          @lonestar2001
          gelöst.
          Der Server hat die Parameter in dieser Form erwartet:

          const payload = new URLSearchParams();
          payload.append('username',this.config.clientLogin);
          payload.append('password',passwordHashed);
          
          1 Antwort Letzte Antwort
          0
          Antworten
          • In einem neuen Thema antworten
          Anmelden zum Antworten
          • Älteste zuerst
          • Neuste zuerst
          • Meiste Stimmen


          Support us

          ioBroker
          Community Adapters
          Donate

          597

          Online

          32.7k

          Benutzer

          82.4k

          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