Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. Adapter mit Bilder-Upload

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Adapter mit Bilder-Upload

    This topic has been deleted. Only users with topic management privileges can see it.
    • SKB
      SKB Developer Most Active @haus-automatisierung last edited by

      @haus-automatisierung Ne, ich meine, wenn der User nun Bilder hochgeladen hat, die ich abrufen möchte. Da kenne ich ja nicht jeden Dateinamen. So bekäme ich das Verzeichs, oder?

      https://github.com/ioBroker/ioBroker.socket-classes?tab=readme-ov-file#readdir_adapter-dirname-options-callback

      haus-automatisierung 1 Reply Last reply Reply Quote 0
      • haus-automatisierung
        haus-automatisierung Developer Most Active @SKB last edited by

        @skb sagte in Adapter mit Bilder-Upload:

        Da kenne ich ja nicht jeden Dateinamen.

        Den Namen musst Du einfach als Attribut irgendwo anders speichern (in das Instance-Objekt o.ä. wo. der Rest deiner Config auch liegt).

        SKB 2 Replies Last reply Reply Quote 0
        • SKB
          SKB Developer Most Active @haus-automatisierung last edited by

          @haus-automatisierung Aber, mit dem readDir komme ich ja auch weiter. Ich schaue mal, wie das geht. Danke!
          Dann geht dies ja wirklich besser, als gedacht 👌

          1 Reply Last reply Reply Quote 0
          • SKB
            SKB Developer Most Active @haus-automatisierung last edited by SKB

            @haus-automatisierung Also so:

            let fileData = await readImage(file);
            
            const response = await new Promise((resolve) => {
                socket.emit('writeFile64', appProperties.namespace, 'userFiles/' + filename, fileData, (res) => { resolve(res); });
            });
            
            console.log(response);
            

            Bekomme ich "null" zurück -.-

            Auch ein:

            const response_folder = await new Promise((resolve) => {
                socket.emit('mkdir', appProperties.namespace, 'userFiles', (error) => { resolve(error); })
            });
            console.log(response_folder);
            

            Liefert leider "null".

            haus-automatisierung 1 Reply Last reply Reply Quote 0
            • SKB
              SKB Developer Most Active last edited by

              Oder, kann man diese Commandos nun nicht über die "normale" socket Verbindung nutzen? Muss dazu doch noch der socket-client auf ioBroker installiert sein?

              1 Reply Last reply Reply Quote 0
              • SKB
                SKB Developer Most Active last edited by SKB

                Ah, read the manual hilft auch weiter 😄 Gibt null, wenn kein Fehler auftaucht. Also, der "upload" klappt sehr gut. Dankeschön erstmal!

                Jetzt wäre natürlich die Frage, kommt man "so" an das Bild heran? Ich würde dem User gerne eine Auswahl seiner Bilder geben, die er nutzen kann und dann sieht er ja den Namen der Datei. Somit wäre es dann gut zu wissen, wie ich dann an die Datei komme und sie ausliefern kann - über den WebAdapter dann.

                Die Datei steckt ja nun in der ioBroker DB. Wie könnte man sie via URL anzeigen?

                Eine Idee?

                Edit: Ist es richtig, das die Datei dann einfach über den Admin Adapter kommt? Habe ich nun mal "getestet" - über:
                http://192.168.70.70:8081/files/Adapter.Instanz/Dateiname.jpg kommt genau das Base64 👌

                @haus-automatisierung @Jey-Cee
                Kann man sich darauf verlassen, das der Admin Adapter immer auf Port 8081 läuft? Nein, oder?
                Welche Admin Instanz wird denn für die Datei-Ablage/Anzeige genutzt?

                Aber: Dies funktioniert ja z.B. nicht von extern, denke ich, weil das Bild ja statisch verlinkt würde und dann auf den Host des Admin-Adapter zeigt. Ich frage mich noch, ob man das Bild nicht auch vom WebAdapter ausliefern lassen könnte?

                haus-automatisierung OliverIO 2 Replies Last reply Reply Quote 0
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @SKB last edited by

                  @skb sagte in Adapter mit Bilder-Upload:

                  Edit: Ist es richtig, das die Datei dann einfach über den Admin Adapter kommt?

                  Das sollte über den Web-Adapter auch so funktionieren. Müsste ich auch testen.

                  SKB 1 Reply Last reply Reply Quote 0
                  • SKB
                    SKB Developer Most Active @haus-automatisierung last edited by

                    @haus-automatisierung

                    http://192.168.70.70:8082/files/Adapter.Instanz/Dateiname.jpg erscheint leider nichts
                    auch nicht via:
                    http://192.168.70.70:8082/Adapter.Instanz/Dateiname.jpg

                    haus-automatisierung 1 Reply Last reply Reply Quote 0
                    • haus-automatisierung
                      haus-automatisierung Developer Most Active @SKB last edited by

                      @skb sagte in Adapter mit Bilder-Upload:

                      http://192.168.70.70:8082/Adapter.Instanz/Dateiname.jpg

                      Das muss gehen. Aber halt nur, wenn das nicht angehakt ist

                      Screenshot 2024-06-20 at 12.43.14.png

                      SKB 1 Reply Last reply Reply Quote 0
                      • SKB
                        SKB Developer Most Active @haus-automatisierung last edited by

                        @haus-automatisierung Ist bei mir nicht angehakt. Daher wundere ich mich.

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

                          @skb sagte in Adapter mit Bilder-Upload:

                          über den WebAdapter dann

                          evtl kannst du die Extenstion Funktionalität des Web-Adapters nutzen.

                          https://github.com/ioBroker/ioBroker.web/blob/master/WEB-EXTENSIONS-HOWTO.md

                          allgemein zu writeFile und readFile.
                          ich gehe mal davon aus, das du es im rahmen eines eigenen adapter einsetzt und nicht aus dem javascript-adapter

                          wir gehen von folgendem adapter aus: demoadapter mit instanz 0
                          wenn ich dort mit writeFile("abc.txt",dateiinhalt);
                          schreibe, dann ist die datei im folgenden verzeichnis zu finden (wenn nicht redis eingesetzt, aber ist ja wie gesagt irrelevant.)

                          iobroker/iobroker-data/files/demoadapter.0/abc.txt
                          

                          wenn du diese datei dann über den webadapter abrufen möchtest, dann müsste der pfad unter

                          http://192.168.x.x:8082/demoadapter.0/abc.txt
                          

                          zu finden sein
                          die extension für den web-adapter kannst du nutzen, wenn du beim ausliefern noch was machen willst.
                          beispieladapter, die das einsetzen
                          Cameras: https://github.com/ioBroker/ioBroker.cameras/blob/master/lib/web.js
                          Simple-api: https://github.com/ioBroker/ioBroker.simple-api/blob/master/lib/simpleapi.js#L73
                          Proxy: https://github.com/ioBroker/ioBroker.proxy/blob/master/lib/proxy.js#L20
                          Eufy-Security: https://github.com/bropat/ioBroker.eufy-security/blob/master/src/lib/web.ts (Typescript-implementation)
                          REST-API: https://github.com/ioBroker/ioBroker.rest-api/blob/master/src/lib/rest-api.js#L67

                          SKB OliverIO 2 Replies Last reply Reply Quote 1
                          • SKB
                            SKB Developer Most Active @OliverIO last edited by SKB

                            @oliverio Danke für deine Ausführungen. Soweit bin ich schon und das klappt auch alles so 😉

                            Bild wird in den Adapter-Pfad geschrieben, Web-Extension per Instanz geht auch 🙂

                            Nur war von deinen Vorrednern die Rede, das ich doch meine Dateien mit Bordmitteln "in die Daten" des ioBroker schreiben soll. Das geht nur soweit, das ich die Datei als "base64" schreibe. Sie ist dann "irgendwo".

                            Über den Admin Adapter Port 8081 komme ich dann an die Datei. Das ist auch gut - oder weniger, wenn ich das Bild doch gerne über den Web-Adapter haben möchte. Denn, wenn man relative Pfade nehmen wollen würde, würde die Datei ja per ioBroker extern nicht geladen werden können, da sie nur via Admin kommt.

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

                              @oliverio sagte in Adapter mit Bilder-Upload:

                              wenn du diese datei dann über den webadapter abrufen möchtest, dann müsste der pfad unter

                              http://192.168.x.x:8082/demoadapter.0/abc.txt
                              

                              der port des web-adapters ist 8082

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

                                @oliverio ja, ist richtig.

                                Sind aber jetzt 2 Dinge von denen wir sprechen.

                                Mache ich den Upload über meinen Adapter per WriteFile via sendTo ist er im WebAdapter über die Extensions verfügbar.

                                Mache ich den Upload über socket.emit('writeFile64', ...) landet er in den Objekten von ioBroker und kommt nur über den Admin http://x.x.x.:8081/files/...

                                Zu 2. Kommt man an die Datei auch per WebAdapter?

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

                                  @skb benenne mal den kompletten sendTo-Befehl

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

                                    @oliverio weiter oben: https://forum.iobroker.net/post/1172033

                                    1 Reply Last reply Reply Quote 0
                                    • haus-automatisierung
                                      haus-automatisierung Developer Most Active @SKB last edited by haus-automatisierung

                                      @skb sagte in Adapter mit Bilder-Upload:

                                      @haus-automatisierung Also so:

                                      let fileData = await readImage(file);
                                      
                                      const response = await new Promise((resolve) => {
                                          socket.emit('writeFile64', appProperties.namespace, 'userFiles/' + filename, fileData, (res) => { resolve(res); });
                                      });
                                      
                                      console.log(response);
                                      

                                      Bekomme ich "null" zurück -.-

                                      Auch ein:

                                      const response_folder = await new Promise((resolve) => {
                                          socket.emit('mkdir', appProperties.namespace, 'userFiles', (error) => { resolve(error); })
                                      });
                                      console.log(response_folder);
                                      

                                      Liefert leider "null".

                                      Mh? In beiden Fällen gibst Du error in resolve() als Rückgabewert (auch wenn Du den Parameter einmal res genannt hast). Und wenn error == null ist, dann hat doch alles geklappt? Was hast Du erwartet?

                                      SKB 1 Reply Last reply Reply Quote 0
                                      • SKB
                                        SKB Developer Most Active @haus-automatisierung last edited by

                                        @haus-automatisierung das habe ich ja oben korrigiert. Klappt ja soweit. Nur die Frage weiterhin, wie ich nun die Bilder nicht über Admin, sondern über den WebAdapter bekomme ...

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

                                          @skb

                                          und wo hat iobroker die dateien den im dateisystem bei dir abgelegt?
                                          bei dem sento bin ich mir jetzt nicht sicher, aber du sendest da nur eine erfolgsmeldung?
                                          aber kein upload?
                                          du schreibst die datei ja mit fs.writeFile

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

                                            @oliverio

                                            const response = await new Promise((resolve) => {
                                            	socket.emit('sendTo', appProperties.namespace, '_uploadFile', { fileName: filename, fileData: file }, (res) => { resolve(res); })
                                            });
                                            

                                            Hier schicke ich die Datei von der Webseite zu meinem Adapter. fileData hat dann den Base64 String der Datei.

                                            Und hier schreibe ich sie im Adapter in den Ordner der iobroker-data. In dem Falle /opt/iobroker/iobroker-data/energiefluss-erweitert.0/userFiles

                                            case '_uploadFile':
                                            const uploadPath = path.join(instanceDir + userFiles, obj.message.fileName);
                                            if (!fs.existsSync(uploadPath)) {
                                            	this.log.info(`Uploading a new file to: ${uploadPath}`);
                                            	fs.writeFile(uploadPath, obj.message.fileData, 'binary', (err) => {
                                            		if (err) {
                                            			this.log.error(`Could not upload the file ${uploadPath}. Error: ${err}`);
                                            			this.sendTo(obj.from, obj.command, { error: err, url: null }, obj.callback);
                                            		} else {
                                            			this.sendTo(obj.from, obj.command, { error: null, url: obj.message.fileName, msg: 'File uploaded successfully!' }, obj.callback);
                                            		}
                                            	});
                                            } else {
                                            	this.log.warn(`The file trying to upload already exists: ${uploadPath}`);
                                            	this.sendTo(obj.from, obj.command, { error: 'File already exists!', url: obj.message.fileName }, obj.callback);
                                            }
                                            
                                            break;
                                            

                                            Die Datei bekomme ich dann per WebAdapter angezeigt via:
                                            http://192.168.2.19:8082/energiefluss-erweitert.0/userFiles/background.jpg

                                            Ich komme aber mit dem Anderen Weg nur über Admin an die Datei, wenn ich sie per:
                                            socket.emit('writeFile64', appProperties.namespace, 'userFiles/' + filename, fileData, (res) => { resolve(res); }); "direkt" zu ioBroker sende.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            484
                                            Online

                                            31.7k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            55
                                            2478
                                            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