trrunde Skrevet 7. august 2005 Del Skrevet 7. august 2005 (endret) Jeg holder på å lage en innlogningsside med mysql, men når brukerene skal få endre passordet prøvde jeg sånn: <? $Gammelt=$_POST['txtGammelt']; if($Gammelt!=''){ //Endre passordet $Nytt=$_POST['txtNytt']; $Gjenta=$_POST['txtGjenta']; if ($Nytt=$Gjenta){ //De har skrevet samme pwd i begge boksene include 'db.php'; //Sjekk om gammelt pwd er det samme som det som er lagret $Username='Trrunde'; $password=md5($Gammelt); $Registrert=mysql_query("SELECT PASSWORD FROM users WHERE username='$Username' AND password='$password' "); $Registrert= mysql_result($Registrert,0); if($password=$Registrert){ //Endre passordet: $Gjenta=md5($Gjenta); mysql_query("UPDATE users SET PASSWORD='$Gjenta' WHERE username='$Username'"); echo 'Passordet ble endret'; echo '<br><a href="welcome.php">Hovedsiden</a>'; } else{ //De skrev feil passord echo 'Du skrev feil passord!'; }; } else{ //De har ikke samme passord i begge boksene echo 'Du skrev ikke samme passordet i begge boksene!'; }; } else{ //Vis skjemaet: ?> <form action="endrepassord.php" method="post" name="Endre passord" id="Endre passord"> <table width="280" border="1"> <tr> <td width="134">Gammelt passord </td> <td width="130"><input name="txtGammelt" type="password" id="txtGammelt"></td> </tr> <tr> <td>Nytt passord </td> <td><input name="txtNytt" type="password" id="txtNytt"></td> </tr> <tr> <td>Gjenta nytt passord </td> <td><input name="txtGjenta" type="password" id="txtGjenta"></td> </tr> </table> <br> <input type="submit" name="Submit" value="Endre passord"> </form> <? }; ?> Dette virket når det bare var en person som var lagret i databasen, men når det er flere får jeg denne meldingen: Warning: mysql_result(): Unable to jump to row 0 on MySQL result index 4 in f:\trrunde's web\mysql\endrepassord.php on line 14 Du skrev feil passord! Endret 7. august 2005 av trrunde Lenke til kommentar
trrunde Skrevet 7. august 2005 Forfatter Del Skrevet 7. august 2005 (endret) Har funnet ut av det, bruker mysql_fetch_row, fant også ut at jeg kan bruke denne metoden men jeg hadde satt $username til Trrunde derfor virket det ikke Endret 7. august 2005 av trrunde Lenke til kommentar
trrunde Skrevet 7. august 2005 Forfatter Del Skrevet 7. august 2005 (endret) Nå har jeg ett nytt problem, når brukeren skriver feil passord kommer denne meldingen opp: Warning: mysql_result(): Unable to jump to row 0 on MySQL result index 5 in f:\trrunde's web\mysql\endrepassord.php on line 16 Du skrev feil passord! Tilbake Den skal skrive ut at du skrev feil passord og tilbake, men hvordan får jeg vekk den feilmeldingen? Edit fant ut av det: i spørringen var det med brukernavn og passord, men siden passordet var feil fant den aldri riktig. Endret 7. august 2005 av trrunde Lenke til kommentar
diskvask Skrevet 7. august 2005 Del Skrevet 7. august 2005 (endret) Sjekk at resultatet av mysql_query() faktisk inneholder en rad. /* Hvis antall rader er større enn null, utfør mysql_result uten å risikere å få feilmelding */ if (mysql_num_rows($Registrert) > 0) { $r_resultat = mysql_result($Registrert, 0); .... } else ... Endret 7. august 2005 av diskvask Lenke til kommentar
trrunde Skrevet 7. august 2005 Forfatter Del Skrevet 7. august 2005 Har fått det til Lenke til kommentar
Anbefalte innlegg
Opprett en konto eller logg inn for å kommentere
Du må være et medlem for å kunne skrive en kommentar
Opprett konto
Det er enkelt å melde seg inn for å starte en ny konto!
Start en kontoLogg inn
Har du allerede en konto? Logg inn her.
Logg inn nå