tietoturvallinen lomake

php-aloittelija

Jos teen nettisivulle tekstikentän ja sovelman käyttäjä kirjoittaa kenttään PHP-kooodia, niin se käsittääkseni suoritetaan jos sivu ladataan uudelleen. Miten voin luoda tarkistuksen, että koodia ei suoritettaisi? Ongelmana on se, että PHP-koodia voi syöttää niin monessa muodossa, tavallisena tekstinä, heksakoodena jne. Olisi kiva nähdä esimerkkikoodi, joka hyväksyisi vain syötteen "aa", mutta ei mitään muuta syötettä, ei edes aa:n heksakoodivastinetta. Ilmeisesti tämä tehdään jotenkin säännöllisten lausekkeiden avulla?

3

1013

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • juhakorkeapudas

      Ongelma tulee silloin jos suoritat esimerkiksi tietokantakyselyitä ja käyttäjä syöttää hakukenttään sopivan merkkijonon, ja ellei hakukentän syötteestä ole poistettu kiellettyjä merkkejä, seuraukset voivat olla ikäviä. Pelkän hakutoiminnon avulla tietokantaan voi esim. syöttää ilkikurisen käyttäjän haluamaa tietoa. Tämä tieto voi olla esim. kirjautumiseen käytetyn tunnuksen salasanan vaihto yms.

      Tekstikenttään syötetty koodi ei aiheuta ongelmaa ellei taustalla ole jokin sellainen toiminto, jota pystyy hyväksikäyttämään koodin avulla.

      Helpoiten merkkijonosta karsii "kielletyt" merkit käyttämällä korvausfunktiota säännöllisen lausekkeen kanssa.

      $input = preg_replace("/[^a-zA-Z0-9@.]/", "", $input);

      Toinen hyvä funktio on otsikossa mainittu Strip_tags, joka poistaa merkkijonosta kaikki html ja php tagit.


      http://fi2.php.net/manual/en/function.preg-replace.php

      http://fi2.php.net/manual/en/function.strip-tags.php

      • ejjej

        Hyvä perussääntö on että data tallennetaan muuttumattomana, VAIN vaaralliset merkit tehdään vaarattomaksi EI poisteta. Käyttämällä http://php.net/pdo.prepare joka on suositus, niin PHP tekee tuon puolestasi.

        Jos ei ole mahdollista käyttää PDO:ta niin silloin käytetään functiota joka on suunniteltu sille tietokannalle jota käytetään, esim MySQL - http://php.net/mysql-real-escape-string


        "Helpoiten merkkijonosta karsii "kielletyt" merkit käyttämällä korvausfunktiota säännöllisen lausekkeen kanssa."

        Miksi karsia?
        Jos lomakkeessa ilmoitetaan esim pelkkiä kirjaimia ja käyttäjä kirjoittaa lisäksi numeroita, tällöin tulostetaan käyttäjälle lomake syötettyinä datoineen virheilmoitus jotta on mahdollista korjata virheensä.

        Joissain tapauksissa toimivin on, että poistetaan virheellinen data mutta ennen tallentamista näytetään kävijälle mimmoisena data tallennetaan ja haluaako hän sen tallentaa vielä, näin vältetään ihan vääränä tallentunut sisältö.


        "$input = preg_replace("/[^a-zA-Z0-9@.]/", "", $input);"

        Ilmeisesti emaileihin?
        Tuo muuttaa sallitut email-osoitteet toisenlaiseksi, jolloin joko viesti ei mene kenellekkään tai menee ihan väärälle. http://en.wikipedia.org/wiki/E-mail_address#RFC_Examples

        Käyttäkäämme http://php.net/book.filter (filter_var, FILTER_VALIDATE_EMAIL), muutenkin tuota filteria kannattaa käyttää tämmöisissä asioissa. Sekä tuo on nopeempakin kun omat toteutukset, kun on tehty PHP-tulkin koodiin.


        "Toinen hyvä funktio on otsikossa mainittu Strip_tags, joka poistaa merkkijonosta kaikki html ja php tagit."

        Data muuttumattomana kantaan, nettisivuille (XHTML) tulostaessa laitetaan htmlspecialchars-function éi htmlentities-function kautta. Tällöin datan saa helposti mihintahansa esitysmuotoon ja pystyy poistamaan/muuttamaan halutut merkit. Toki tällöin täytyy tuntea hieman merkistökoodauksista ettei aiheuta ongelmia.

        Ei tuo strip_tags-functio ole ongelmaton. Lähetän foorumille


      • toimii jossain
        ejjej kirjoitti:

        Hyvä perussääntö on että data tallennetaan muuttumattomana, VAIN vaaralliset merkit tehdään vaarattomaksi EI poisteta. Käyttämällä http://php.net/pdo.prepare joka on suositus, niin PHP tekee tuon puolestasi.

        Jos ei ole mahdollista käyttää PDO:ta niin silloin käytetään functiota joka on suunniteltu sille tietokannalle jota käytetään, esim MySQL - http://php.net/mysql-real-escape-string


        "Helpoiten merkkijonosta karsii "kielletyt" merkit käyttämällä korvausfunktiota säännöllisen lausekkeen kanssa."

        Miksi karsia?
        Jos lomakkeessa ilmoitetaan esim pelkkiä kirjaimia ja käyttäjä kirjoittaa lisäksi numeroita, tällöin tulostetaan käyttäjälle lomake syötettyinä datoineen virheilmoitus jotta on mahdollista korjata virheensä.

        Joissain tapauksissa toimivin on, että poistetaan virheellinen data mutta ennen tallentamista näytetään kävijälle mimmoisena data tallennetaan ja haluaako hän sen tallentaa vielä, näin vältetään ihan vääränä tallentunut sisältö.


        "$input = preg_replace("/[^a-zA-Z0-9@.]/", "", $input);"

        Ilmeisesti emaileihin?
        Tuo muuttaa sallitut email-osoitteet toisenlaiseksi, jolloin joko viesti ei mene kenellekkään tai menee ihan väärälle. http://en.wikipedia.org/wiki/E-mail_address#RFC_Examples

        Käyttäkäämme http://php.net/book.filter (filter_var, FILTER_VALIDATE_EMAIL), muutenkin tuota filteria kannattaa käyttää tämmöisissä asioissa. Sekä tuo on nopeempakin kun omat toteutukset, kun on tehty PHP-tulkin koodiin.


        "Toinen hyvä funktio on otsikossa mainittu Strip_tags, joka poistaa merkkijonosta kaikki html ja php tagit."

        Data muuttumattomana kantaan, nettisivuille (XHTML) tulostaessa laitetaan htmlspecialchars-function éi htmlentities-function kautta. Tällöin datan saa helposti mihintahansa esitysmuotoon ja pystyy poistamaan/muuttamaan halutut merkit. Toki tällöin täytyy tuntea hieman merkistökoodauksista ettei aiheuta ongelmia.

        Ei tuo strip_tags-functio ole ongelmaton. Lähetän foorumille

        Käytin erään lomakkeen tarkistamiseen sähköpostiosoitteen kohdalla tuota FILTER_VALIDATE_EMAIL-toimintoa. Jostain syystä se toimii omalla kotikoneellani vallan mainiosti, mutta ainakaan mbnet:in serverillä sama koodi ei enää toimikaan. Testailujeni perusteella koodin suoritus tökkää juuri tuohon validointiin, sen jälkeen ei tulosteta näytölle yhtään mitään. Onkohan tuo toiminto otettu joiltain servereiltä pois käytöstä, kun siinä taisi olla joku tietoturvaongelma? Entä tuleeko mieleen joku muu hyvä ja edes melko luotettava keino tarkistaa osoite?


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

    Luetuimmat keskustelut

    1. Hallitus pyrkii rajoittamaan kaupan omien halpamerkkien myyntiä

      Helsingin Sanomien mukaan hallitus valmistelee lakihanketta, joka suitsii kaupan valtaa ja rajoittaa omien halpamerkkien
      Yhteiskunta
      100
      2273
    2. Kysy jotain kaivatultasi

      Tämä ketju on sitä varten.
      Ikävä
      221
      1924
    3. Huomenna sähkö maksaa jo yli 60 snt/kWh. Milloin ALV putoaa?

      Kysynkin persuilta, että milloin aiotte pudottaa sähkön arvonlisäveron kuten Marinin hallitus teki sähkön hinnan noustes
      Maailman menoa
      176
      1752
    4. Persut päättivät hiilivoimaloiden alasajosta

      Persut ovat Suomen kansan vastainen putinistiporukka, josta nyt maksamme kovaa hintaa.
      Maailman menoa
      101
      1316
    5. Tapettu

      On joku kangaskadulla perjantaina
      Sotkamo
      38
      1220
    6. Mitä ajattelet hänestä

      Millaisena pidät kaivattuasi?
      Ikävä
      122
      1108
    7. Onko jollekin vielä epäselvää Raamatun kanta homoseksuaaliseen käytökseen?

      😺 On oma mielipiteesi mikä tahansa on hyvä muistaa, mikä on Jumalan mielipide. Edelliset ketjut ovat tulleet täyteen jo
      Luterilaisuus
      276
      823
    8. 90kW kulutus

      Joku kirjoitti sellaisesta tehomaksuaiheen yhteydessä. Tuollainen kulutushan vaatisi pääsulakkeiden kooksi jo vaikka mit
      Maailman menoa
      180
      681
    9. Mietin sua liikaa

      Mietin nytkin sitä, että millaista se olisi tulla kotiin, kun sinä olisit täällä vastassa. Tai niin päin, että sinä tuli
      Ikävä
      47
      655
    10. Vanhemmassa miehessä

      on sellaista elämän mukana tullutta viehättävää charmia. Hän paranee iän myötä niinkuin hyvä viini tai juusto! Tuli tuo
      Ikävä
      50
      651
    Aihe