Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Daten aus PW geschützte Website

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    Daten aus PW geschützte Website

    This topic has been deleted. Only users with topic management privileges can see it.
    • Negalein
      Negalein Global Moderator last edited by

      Hallo

      Ist es irgendwie möglich, Daten aus einer PW-geschützten Website auszulesen?

      f03a2166-94ca-4033-bcb9-0944b87f0adf-image.png

      92e610d4-ab32-4abb-9abd-9df55c0f2b9b-image.png

      Codierknecht 1 Reply Last reply Reply Quote 0
      • Codierknecht
        Codierknecht Developer Most Active @Negalein last edited by

        @negalein
        Vielleicht klappt das:

        https://user:password@adresse.de
        
        Negalein OliverIO 2 Replies Last reply Reply Quote 0
        • Negalein
          Negalein Global Moderator @Codierknecht last edited by

          @codierknecht sagte in Daten aus PW geschützte Website:

          Vielleicht klappt das:

          ich möchte gern nur den Preis auslesen und in einen DP schreiben.
          Leider hab ich von JS 0 Ahnung.

          Codierknecht 1 Reply Last reply Reply Quote 0
          • Codierknecht
            Codierknecht Developer Most Active @Negalein last edited by

            @negalein sagte in Daten aus PW geschützte Website:

            Leider hab ich von JS 0 Ahnung

            Das ist ja auch der URL - hat mit JS nix zu tun.
            Zum Auslesen kannst Du dann den Parser-Adapter verwenden.

            Negalein 1 Reply Last reply Reply Quote 1
            • Negalein
              Negalein Global Moderator @Codierknecht last edited by Negalein

              @codierknecht sagte in Daten aus PW geschützte Website:

              Zum Auslesen kannst Du dann den Parser-Adapter verwenden.

              wüsstest du vielleicht noch, was dann ins Feld RegEx kommt?

              So kommt die komplette Seite
              d09a0d9d-06c1-4886-8a70-a6e0b5a083ef-image.png

              06253916-e52e-42cd-a143-9ce944a509a0-image.png

              Im Quelltext kommt dies vor.

              <div class="preismast hidden-xs">
              										<div style="color:#FEFEFE; text-align:center">05.12.2022-11.12.2022</div>
              										<div class="preismastDieselPreis">1,685</div>
              										<div class="preismastBenzinPreis">1,498</div>
              										<div class="preismastSuperPreis">1,498</div>
              										<div class="preismastSuperplusPreis">1,642</div>
              										</div>
              

              Benötigen würde ich den Preis von preismastDieselPreis

              Codierknecht 1 Reply Last reply Reply Quote 0
              • Codierknecht
                Codierknecht Developer Most Active @Negalein last edited by

                @negalein sagte in Daten aus PW geschützte Website:

                wüsstest du vielleicht noch, was dann ins Feld RegEx kommt?

                (?<=DieselPreis\"\>)(.*?)(?=\<)
                

                https://letmegooglethat.com/?q=regex+match+between+two+strings

                Negalein 1 Reply Last reply Reply Quote 0
                • Negalein
                  Negalein Global Moderator last edited by

                  @codierknecht sagte in Daten aus PW geschützte Website:

                  (?<=DieselPreis">)(.*?)(?=<)

                  im Log kommt dann Cannot find number in answer for parser.0.IQ

                  https://letmegooglethat.com/?q=regex+match+between+two+strings

                  Hihi, die Tante hab ich gefragt. Aber nur auf deutsch.

                  1 Reply Last reply Reply Quote 0
                  • Negalein
                    Negalein Global Moderator @Codierknecht last edited by

                    @codierknecht

                    PS: ich würde den Preis benötigen. Aktuell sind es die 1,685

                    <div class="preismastDieselPreis">1,685</div>

                    Codierknecht 1 Reply Last reply Reply Quote 0
                    • Codierknecht
                      Codierknecht Developer Most Active @Negalein last edited by

                      @negalein

                      DieselPreis\"\>(.*)\<
                      

                      da63d939-aa6a-46fa-99cd-935a3ef2f999-image.png

                      Negalein 1 Reply Last reply Reply Quote 0
                      • Negalein
                        Negalein Global Moderator @Codierknecht last edited by

                        @codierknecht sagte in Daten aus PW geschützte Website:

                        DieselPreis">(.*)<

                        ich komm nicht weiter.
                        Habe jetzt bemerkt, dass im Quelltext, den der Parser ausliest, der DieselPreis nicht enthalten ist.


                        neu 12.txt


                        neu 13.txt

                        Warum liest der Parser den Quelltext anders aus?

                        Codierknecht 1 Reply Last reply Reply Quote 0
                        • Codierknecht
                          Codierknecht Developer Most Active @Negalein last edited by

                          @negalein sagte in Daten aus PW geschützte Website:

                          Habe jetzt bemerkt, dass im Quelltext, den der Parser ausliest, der DieselPreis nicht enthalten ist.

                          Das ist die Anmeldeseite. Offenbar kommt man über Benutzername/Kennwort als Teil des URL nicht rein.

                          Negalein 1 Reply Last reply Reply Quote 1
                          • Negalein
                            Negalein Global Moderator @Codierknecht last edited by

                            @codierknecht sagte in Daten aus PW geschützte Website:

                            Das ist die Anmeldeseite. Offenbar kommt man über Benutzername/Kennwort als Teil des URL nicht rein.

                            schade 🙁

                            1 Reply Last reply Reply Quote 0
                            • OliverIO
                              OliverIO @Codierknecht last edited by

                              @codierknecht sagte in Daten aus PW geschützte Website:

                              https://user:password@adresse.de

                              das ist eine authentifizierungsmethode die eigentlich gar nicht mehr benutzt werden soll. manche seiten unterstützen das zwar noch, ist aber bei modernen seiten eher unüblich.
                              meist wird oauth genommen (aber es gibt glaube ich noch 2-3 andere relevante)
                              aber all dies kann der parser adapter nicht, dann muss da immer auf ein skript zurückgegriffen werden.

                              warum sind diese Preise nicht im adapter tankerkönig enthalten?

                              Negalein Codierknecht 3 Replies Last reply Reply Quote 0
                              • Negalein
                                Negalein Global Moderator @OliverIO last edited by

                                @oliverio sagte in Daten aus PW geschützte Website:

                                dann muss da immer auf ein skript zurückgegriffen werden.

                                also mit einem Script würde es funktionieren?

                                @oliverio sagte in Daten aus PW geschützte Website:

                                warum sind diese Preise nicht im adapter tankerkönig enthalten?

                                dies sind Spezialpreise von einem Verein ausgehandelt.

                                OliverIO 1 Reply Last reply Reply Quote 0
                                • OliverIO
                                  OliverIO @Negalein last edited by OliverIO

                                  @negalein
                                  ich denke schon. das skript muss genau das machen, was der anwender macht.
                                  das kann auch etwas aufwändiger sein, also nicht nur 2-3 zeilen.
                                  wenn der anbieter es einem noch schwerer machen will kann er auch dinge einbauen, die es nicht mehr mit vertretbaren aufwand rechtfertigt.
                                  ggfs kann man auch mit pupettier arbeiten, darüber den anmelde vorgang durchführen und dann erst die ergebnisseite auswerten.
                                  allerdings ist das resourcentechnisch auch aufwändig (kompletter browser wird im hintergrund geladen)

                                  daher: gibt es die preise nicht auch noch woanders?

                                  Negalein 1 Reply Last reply Reply Quote 0
                                  • Negalein
                                    Negalein Global Moderator @OliverIO last edited by

                                    @oliverio sagte in Daten aus PW geschützte Website:

                                    das kann auch etwas aufwändiger sein, also nicht nur 2-3 zeilen.

                                    ich hab von JS leider 0 Ahnung.
                                    Könntest du sowas? Natürlich nicht umsonst.

                                    daher: gibt es die preise nicht auch noch woanders?

                                    genau.
                                    Diese Preise gelten österreichweit von Montag bis Sonntag

                                    OliverIO 1 Reply Last reply Reply Quote 0
                                    • OliverIO
                                      OliverIO last edited by

                                      @negalein

                                      ich könnte mal reinschauen und eine vorabanalyse machen.
                                      dazu würde ich aber den Zugang benötigen oder gibt es einen demo-zugang?

                                      Negalein 1 Reply Last reply Reply Quote 0
                                      • Negalein
                                        Negalein Global Moderator @OliverIO last edited by

                                        @oliverio sagte in Daten aus PW geschützte Website:

                                        dazu würde ich aber den Zugang benötigen oder gibt es einen demo-zugang?

                                        PN

                                        1 Reply Last reply Reply Quote 0
                                        • Codierknecht
                                          Codierknecht Developer Most Active @OliverIO last edited by

                                          @oliverio sagte in Daten aus PW geschützte Website:

                                          das ist eine authentifizierungsmethode die eigentlich gar nicht mehr benutzt werden soll

                                          Ist aber noch nicht bei allen Seitenbetreibern angekommen ... hier offenbar schon ;.)

                                          Security sucks 😁

                                          1 Reply Last reply Reply Quote 0
                                          • OliverIO
                                            OliverIO @Negalein last edited by OliverIO

                                            @negalein

                                            so hier ist das script.
                                            allerdings war es doch eine kleine Herausforderung, da ich 3 Bibliotheken (node-fetch,axios,cURL) probieren musste und dann doch am alten request/request hängen geblieben bin.
                                            Diese bibliothek ist zwar deprecated (weil zu Ende entwickelt), aber die einzige
                                            die sogenannte cookie-jars unterstützt, bzw wo es auch funktioniert.
                                            Da hier die Anmeldung über mehrere Seitenaufrufe realisiert wird und die SessionID sozusagen als Authentifizierungs-Token dient, müssen die cookies hier bei jedem request mitgeführt werden.
                                            OK es wäre auch anders gegangen, aber ich war faul.

                                            du musst nur noch deinen user und passwort wieder ins skript eintragen und laufen lassen.
                                            der datenpunktname ebenfalls noch anpassen und er muss vor start existieren.
                                            da ich alle werte (alle treibstoffarten+gültigkeit+preis) auslese, habe ich diese in ein json gesammelt und das landet dann im datenpunkt.

                                            wenn die richtige seite dann geladen ist, wird mit cheerio (dies bildet jquery ausserhalb des browsers nach), wird die html-dom gelesen, die werte extrahiert und noch ein wenig bereinigt.

                                            es ist jetzt alles sehr kompakt, wer fragen hat, weil er was nicht lesen oder verstehen kann, kann gerne fragen.

                                            dieser Lösungsansatz wäre für alle Formular+Session basierten Authentifizierungen möglich.

                                            const dpPrices = "javascript.0.test1";
                                            var user = "xxx";
                                            var pass = "xxx";
                                            
                                            
                                            const request = require("request");
                                            const cheerio = require("cheerio");
                                            
                                            async function main() {
                                            
                                              var optionsLogin = {
                                                method: 'POST',
                                                url: "https://netservice.iqcard.at/de/login",
                                                body: "BENUID=" + user + "&PASSWT=" + pass + "&login-form-submit=login",
                                                jar: true,
                                                followRedirect:true,
                                                followAllRedirects :true,
                                                headers: {
                                                  "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
                                                  "accept-encoding": "gzip, deflate, br",
                                                  "accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
                                                  "cache-control": "no-cache",
                                                  "content-type": "application/x-www-form-urlencoded",
                                                  "dnt": "1",
                                                  "origin": "https://netservice.iqcard.at",
                                                  "pragma": "no-cache",
                                                  "sec-ch-ua": "\"Not?A_Brand\";v=\"8\", \"Chromium\";v=\"108\", \"Google Chrome\";v=\"108\"",
                                                  "sec-ch-ua-mobile": "?0",
                                                  "sec-ch-ua-platform": "\"Windows\"",
                                                  "sec-fetch-dest": "empty",
                                                  "sec-fetch-mode": "cors",
                                                  "sec-fetch-site": "same-origin",
                                                  "upgrade-insecure-requests": "1",
                                                  "User-Agent": " Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36",
                                                  "cookie": "cAccept=true; NETSERVICE=true; IQCARDPASSWT=; IQCARDBENUID= ",
                                                  "Referer": "https://netservice.iqcard.at/de/kunden"
                                                }
                                              };
                                              var optionsPriceinfo = {
                                                method: 'GET',
                                                url: "https://netservice.iqcard.at/de/netservice_preisinfo",
                                                jar: true,
                                                followRedirect:true,
                                                followAllRedirects :true,
                                                headers: {
                                                  "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
                                                  "accept-encoding": "gzip, deflate, br",
                                                  "accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
                                                  "cache-control": "no-cache",
                                                  "dnt": "1",
                                                  "origin": "https://netservice.iqcard.at",
                                                  "pragma": "no-cache",
                                                  "sec-ch-ua": "\"Not?A_Brand\";v=\"8\", \"Chromium\";v=\"108\", \"Google Chrome\";v=\"108\"",
                                                  "sec-ch-ua-mobile": "?0",
                                                  "sec-ch-ua-platform": "\"Windows\"",
                                                  "sec-fetch-dest": "empty",
                                                  "sec-fetch-mode": "cors",
                                                  "sec-fetch-site": "same-origin",
                                                  "sec-fetch-user": "?1",
                                                  "upgrade-insecure-requests": "1",
                                                  "User-Agent": " Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36",
                                                  "Referer": "https://netservice.iqcard.at/de/netservice"
                                                }
                                              };
                                              request.jar();
                                              request.post(optionsLogin,()=>{
                                                request.get(optionsPriceinfo,(error, response, body)=>{
                                                  const $ = cheerio.load(body);
                                                  let titles = $('div[class="panel-body"] > fieldset > legend > strong').map((i,el)=>$(el).text().replace("Preise","").trim());
                                                  let dates = $('div[class="panel-body"] > fieldset').contents().filter(function() {
                                                    return this.nodeType == 3 && this.data.replace(/\s/gm,"")!=""
                                                  }).map((i,el)=>$(el).text().replace(/\s/gm,"").slice(0,-1));
                                                  let prices = $('div[class="panel-body"] > fieldset > strong').map((i,el)=>$(el).text());
                                                  if (titles.length==dates.length && titles.length==prices.length) {
                                                    console.debug("website structure OK, found matching elements");
                                                  } else {
                                                    console.debug("website structure is not OK, elements doesnt match");
                                                    return;
                                                  }
                                                  let data={};
                                                  for (var i=0;i<titles.length;i++) {
                                                    data[titles[i]]={
                                                      title:titles[i],
                                                      date:dates[i],
                                                      price:prices[i]
                                                    };
                                                  };
                                                  console.debug(data);
                                                  writeDatapoint(data);
                                                });
                                              });
                                              function writeDatapoint(data) {
                                                console.debug("write dpPrices");
                                                setState(dpPrices,JSON.stringify(data));
                                              }
                                            }
                                            main()
                                            
                                            
                                            
                                            
                                            
                                            Negalein 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            943
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            7
                                            126
                                            7086
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo