Pereiti prie turinio

PHP -> arba as zlibas arba nematau klaidos


Rekomenduojami pranešimai

if(isset($_POST['reg'])) {

if((empty($_POST['loginname'])) or (empty($_POST['password']))) { $error = "Uzpildykite laukus"; }

else {

$tikrinti = mysql_query("SELECT * FROM users") or die(mysql_error());

while($row = mysql_fetch_array($tikrinti)) {

$login = $row['login'];

if($_POST['loginname'] == $login) { $error = "Toks prisijungimo vardas jau egzistuooja"; }

else {

mysql_query("INSERT INTO users VALUE('','$_POST[loginname]','$_POST[password]')") or die(mysql_error());

}

}

}

 

 

}

 

 

Taigi, klaida meta bold vietoje, ty nemeta klaidos bet nesuveikia else jei toks loginas egizstuoja vistiek ji imeta i DB.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Mhm kam tu ta cikla kisi cia nelabai supratau.. Tiesiog su select patikrink be ciklo.. Cia tu man aplamai kazkaip keistai viska padares.. ;)

Daryk mazdaug taip:

if((empty($_POST['loginname'])) or (empty($_POST['password']))) { $error = "Uzpildykite laukus"; }
$login="SELECT * FROM users WHERE login=$_POST['loginname']";
if($_POST['loginname'] == $login) { $error = "Toks prisijungimo vardas jau egzistuooja"; }
if($error != "") { echo"Klaida! $error";} 
else { vygdai irasinejima..

 

Cia aisku tik pvz tai jei imsi ir naudosi tikriausiai neveiks nu, bet esme turetum suprast.. :D

Redagavo north
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Galima ir paprasčiau parašyt, norint rasti ar yra toks vartotojo vardas paimtas, ar ne.

 

$vardas = addslashes($_POST['loginname']);
$tikrinti = mysql_query("SELECT * FROM `users` WHERE `vartotojo_vardas` = '$vardas'") or die(mysql_error());

if(mysql_num_rows($tikrinti) > 0) {

 $error = "Toks prisijungimo vardas jau egzistuooja"; 

} else {

 //irasai i db

}

 

edited: beje, tau įrašo į db tą vartotojo vardą, nes tu tikrini visus vardus, o su visais negali sutapti, dėl to ir įrašo. Ir tikriausiai dar ne vieną kartą.

Redagavo Tom
Nuoroda į pranešimą
Dalintis kituose puslapiuose
Galima ir paprasčiau parašyt, norint rasti ar yra toks vartotojo vardas paimtas, ar ne.

 

$vardas = addslashes($_POST['loginname']);
$tikrinti = mysql_query("SELECT * FROM `users` WHERE `vartotojo_vardas` = '$vardas'") or die(mysql_error());

if(mysql_num_rows($tikrinti) > 0) {

 $error = "Toks prisijungimo vardas jau egzistuooja"; 

} else {

 //irasai i db

}

 

 

Deja, vistiek iraso ;)

Nuoroda į pranešimą
Dalintis kituose puslapiuose
zinoma kad ne

Vietoj

`vartotojo_vardas`

užklausoje įrašyk savo, `login` ar kaip ten pas tave eilutė pavadinta su vartotojo vardais.

 

Mhm kam tu ta cikla kisi cia nelabai supratau.. Tiesiog su select patikrink be ciklo.. Cia tu man aplamai kazkaip keistai viska padares.. ;)

Daryk mazdaug taip:

if((empty($_POST['loginname'])) or (empty($_POST['password']))) { $error = "Uzpildykite laukus"; }
$login="SELECT * FROM users WHERE login=$_POST['loginname']";
if($_POST['loginname'] == $login) { $error = "Toks prisijungimo vardas jau egzistuooja"; }
if($error != "") { echo"Klaida! $error";} 
else { vygdai irasinejima..

 

Cia aisku tik pvz tai jei imsi ir naudosi tikriausiai neveiks nu, bet esme turetum suprast.. :D

Kas čia dabar?

Redagavo Tom
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...