Paikallisen kuvan lataaminen sivulle, polun selvittäminen

Anonyymi

Tarkoitus olisi saada käyttäjän valitsemaan omalta koneelta kuva, joka näytettäisiin sivulla.

Kuvan voi valita input-elementillä asettamalla type imageksi.

<input ref="fileList" type="file" accept="image/*"/>

Tuo tekee sivulle valintanappulan, joka aukaisee kuvatiedostojen valintaikkunan. Tiedostolistaus löytyy valinnan jälkeen elementin .files:stä, eli .files[0] on ensimmäinen tiedosto (tai tässä tapauksessa ainoa) jne.

Tarkoitus olisi sitten laittaa kohde-elementin .src:hen tiedostonimi polkuineen, mutta polkuna on "C:\fakepath", kun käyttää elementin value:ta. Tiedosto-objektissa taas ei ole kuin

lastModified: 1519296733000
​name: "testikuva.jpg"
​size: 27033
​type: "image/jpeg"
​webkitRelativePath: ""

On ilmeisesti joku tietoturvasyy miksi polku on piilotettu, mutta tässä tapauksessa kuvaa ei olla lähettämässä (upload) mihinkään, vaan pelkästään näytettäisiin se nettisivulla. Milläköhän tavalla saisi tuon polun selville?

6

263

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      <!DOCTYPE html>
      <html lang="fi">
      <head>
      <meta charset="utf-8" />
      <title>Esimerkki</title>
      <script type='text/javascript'>
      function NäytäKuva(event)
      {
      var reader = new FileReader();
      reader.onload = function()
      {
      var output = document.getElementById('Kuva');
      output.src = reader.result;
      }
      reader.readAsDataURL(event.target.files[0]);
      }
      </script>
      </head>
      <body>
      <input type="file" accept="image/*" onchange="NäytäKuva(event)">
      <br>
      <img id="Kuva"/>
      </body>
      </html>

      • Anonyymi

        Tattis, tuota FileReaderia käyttäen sain toimimaan.


      • Anonyymi
        Anonyymi kirjoitti:

        Tattis, tuota FileReaderia käyttäen sain toimimaan.

        Kännykässä näköjään Firefox Focus ei suostu näyttämään kuvaa, mutta Edge näyttää.


    • Anonyymi

      Mikään skripti ei pääse käsiksi dataan joka on eri lähteessä: https://en.wikipedia.org/wiki/Same-origin_policy

      Eli nettisivusi olisi sitten myös siellä "koneella" missä kuva valitaan. Eli HTTP palvelimella jako missä on se nettisivu ja kuvat niin sitten siellä voi valita.

      • Anonyymi

      • Anonyymi

        Juu, CORS-hässäkkä on tuttu. Tuossa vaan kokeilin Vuessa tehdä komponenttia, johon voi valita näkyvän kuvan paikallisesti. Aloitukseni otsikko oli sikäli harhaanjohtava, kun ei mitään varsinaisesti ladata, vaan pelkästään laitetaan img:n src:ksi valitun kuvan polku.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Mitkä asiat

      tekevät vaikeaksi kohdata kaivattusi?
      Ikävä
      73
      843
    2. Miltä se tuntuu

      Miltä se tuntuu havahtua, että on ollut ihmistä kohtaan, joka on rakastanut ja varjellut, täysi m*lkku? Vai havahtuuko s
      Ikävä
      104
      698
    3. 35
      567
    4. Pidit itseäsi liian

      Vanhana minulle? Niinkö?
      Ikävä
      40
      565
    5. Haluaisitko oikeasti

      Vakavampaa välillemme vai tämäkö riittää
      Ikävä
      46
      560
    6. En mahda sille mitään

      Olet ihanin ja tykkään sinusta todella paljon.
      Ikävä
      29
      552
    7. Rakas

      Eihän se tietysti minulle kuulu, mutta missä sinä olet? 😠
      Ikävä
      31
      540
    8. Joko olet luovuttanut

      Mun suhteen?
      Ikävä
      50
      520
    9. Mitä se olisi

      Jos sinä mies saisit sanoa kaivatullesi mitä vain juuri nyt. Ilman mitään seuraamuksia yms. Niin mitä sanoisit?
      Ikävä
      34
      517
    10. Sinunkin pitää jättää

      Se kaivattusi rauhaan.
      Ikävä
      35
      454
    Aihe