WEB lomakkeeseen neuvoa...

PHP-viallinen

Voisiko joku katsoa oheista koodia ja kertoa mitä kaikkea siinä on vialla..

Lomake..


Palautelomake

3

769

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • teuro

      Toki tuosta voin kertoa heti ettei se näytä kovin hyvältä selaimessa, mutta sitä tuskin haluat kuulla. form action=http... tästä puuttuu aloittava lainausmerkki. Roskapostin esto tuskin toimii, mutta häiritsee normaalia käyttäjää takuulla. Tarkistuskohdassa sulla $_POST['nimi'], mutta edellä olet käyttänyt $_POST['etunimi']?

      Samassa kohdassa mikset käytä suoraan muuttujaa $etunimi? Jossain kohdassa voisi vähän tarkistella mitä noissa muuttujissa onkaan. Jokuhan voisi vaikka kirjoitella hieman haittakoodia ja voitaisiin vaikkapa suoritella palvelimella...

      Puhelinnumeron tarkistus on ihan huuhaata, koska siinä saa olla ihna mitä tahansa paitsi pieniä kirjaimia. Vai tarkoittaako eregi, että mitään kirjaimia ei saa esiintyä, mutta kaikki muu on sallittua. Muutoin samat ongelmat, kuin etunimen kohdalla. Lopuksi pyydät kamalan kasan tietoa lähettäjästä, muttet lähetä niitä itsellesi voitko kertoa miksi näin?

      • PHP-viallinen

        Kiitos vastauksesta, koodi on varmasti puutteellinen...olen eka kertaa mokomaa tekemässä. Lainailin koodinpätkiä sieltä täältä joten epäjohdonmukaisuuksia on kuten kyseltyjen tietojen välitys omaan sähköpostiin. Ajattelin liittää lomakkeeseen jonkun kuvan numerosarjasta jota spämmikone ei osaa lukea, en keksinyt helpompaa keinoa. Jep, puh nro tarkastus on varmaan turha.


    • Jaska Perusjaska

      Tuo ei todennäköisesti toimi, koska käytät palaute-muuttujaa, sekä lomakkeen palautteen muuttujana, että mail()-funktion palauttamaan dataan.

      Ja tosiaan teen aivan turhaan kaiken maailman puhelinnumeroiden tarkistukset, kun et lähetä lomakedatasta muuta kuin palautteen sähköpostiisi.

      Jokaisen lomakekentän sisällön tarkastaminen erikseen on ehkä hieman työlästä, kun koko roskan voisi hoitaa esim. foreachilla. Kaikki lomakedatahan on $_POST-taulukossa. Mielummin tyhjät kentät tarkastettaisiin javascriptilla ennen lomakkeen lähetystä. Muuten kaikki tiedot häviää, jos käyttäjä tekee virheen. Virheilmoituksetkaan ei tulisi näkyviin, koska käyttäjä ohjataan joka tapauksessa pois scriptistä. Joten ne pitäisi muuttaa vaikkapa die("Et antanut x tietoa!");
      Eikä itseasiassa tuosta tarkistuskesta ole mitään hyötyä, koska scripti suoritetaan joka tapauksessa loppuun, oli kaikki kentät tyhjiä tai ei.

      Ja keräät muutenkin turhaan kaikki tiedot omiin muuttujiin, kun et käytä niitä missään.

      Kysyt lomakkeessa tietoja, joihin ei edes viitata scriptissä. Esim. vastaus-kenttä.

      Tuossa eregissäkin on jotain pielessä. Nyt se taitaa hyväksyä kaikki muut merkit paitsi sulut ja kirjaimet a-z. Eregissä ei taida olla merkistystä kirjainten koolla, joten myös A-Z ovat pannassa. Käännä koko lause mielummin toisinpäin, että kaikki muut merkit paitsi 0-9, () ja - hylätään. Helpompi niin.

      Tuo spam-esto saattaa olla toimiva. Ainakin hetken. Olet poistanut osia koodista, joten ei pysty sanomaan. Kyllä kuvastakin pystyy lukemaan tekstiä ja jos joka kerta on sama tarkistuskoodi&kuva, niin kyllä joskus joku robotti sen saa selville. Ja tosiaan käyttäjiä tuollainen vain kiusaa.

      Ei tuo ihan valmis koodi vielä ole, mutta kyllä se siitä :)

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

    Luetuimmat keskustelut

    1. Lataus pakkaskelissä

      En olisi koskaan ostanut sähköautoa jos olisin tajunnut että ne eivät lataa pakkasissa suurteholatauksella vaan istut tu
      Hybridi- ja sähköautot
      174
      6686
    2. Kun väestö ikääntyy ja veronmaksajat vähenee, mitä sitten vasemmistolaiset?

      Maahanmuutto ei vaan ole ratkaisu väestön ikääntymiseen. Maahanmuutto lykkää ja hidastaa väestön ikääntymistä ja työv
      Maailman menoa
      105
      3146
    3. Miksei Trump ole kiinnostunut Suomen valloittamisesta?

      Täällähän on enemmän turvetta kuin Norjalla öljyä. Eikö Ttump ole turvenuija?
      Maailman menoa
      104
      1865
    4. Aktivistinainen pysäytti ICE-agentin luodin päällään USA:ssa!

      Video ampumistilanteesta: https://edition.cnn.com/2026/01/07/us/video/ice-shooting-minneapolis-digvid "Media: ICE:n am
      Maailman menoa
      62
      1649
    5. Tiedän ettei

      Meistä mitään tule. Toinen oli sinulle tärkeämpi
      Ikävä
      18
      1524
    6. "Mitä sä nainen tuot sitten pöytään" ?

      Jos mies provaidaa ja suojelee... Pitääkö miesten kysyä tuollaisia?
      Ikävä
      36
      1354
    7. Kyllä mä suren

      Sitä että mikään ei ole kuten ennen. Ei niitä hetkiä ja katseita. Toisaalta keho lepää eikä enää tarvitse sitä tuskaa ko
      Ikävä
      11
      1310
    8. Laitetaan nyt kirjaimet kohdilleen

      kuka rakastaa ja ketä ?
      Ikävä
      62
      1210
    9. Ekologinen kommunismi tulee voittamaan fossiilikapitalismin

      Kiina on mahtitekijä uusiutuvien energialähteiden kehityksessä, ja Trump osoitus viimeisestä öljyn perään itkemisestä, m
      Maailman menoa
      15
      1203
    10. Yhteen hiileen velanottoveljet V P K

      Tytäryhtiöissä palaa julkista rahaa ja vastuuttomuuden takia -ei pakollisten -kuntalain edellyttämien asioiden takia! N
      Pyhäjärvi
      75
      1143
    Aihe