Avatar billede engaai Nybegynder
24. marts 2004 - 15:40 Der er 6 kommentarer

Problemer med loginsystem

Hej

Jeg har lavet nedenstående script, til at checke om en brugers indtastede brugernavn og password er korrekt. Hvis brugeren indtaster et forkert brguernavn, melder den fejl lige som den skalm men hvis passwordet derimod er forkert, logger den stadigvæk brugeren ind. Hvordan kan det være, og bør jeg opbygge mit script på en anden måde?

Scriptet:


<?

$opret = $_REQUEST['opret'];
$login = $_REQUEST['login'];
$brugernavn = $_REQUEST['brugernavn'];
$password = $_REQUEST['password'];
$self = $_SERVER['REQUEST_URL'];
$form =  "<div class='right_login'>
        <form action='$self' method='post'>
        brugernavn <br /><input class='input_login' type='text' name='brugernavn' />
        <p />
        adgangskode <br /><input class='input_login' type='password' name='password' />
        <input type='submit' name='login' value='Login'>
        <input type='submit' name='opret' value='Opret'>
        </form></div>";
             

if(isset($_SESSION['user'])) {
    echo "Navn:  {$_SESSION['user']}";
} elseif(!isset($opret) && !isset($login)) {
    echo "$form"; 
} elseif(isset($opret)) {   
    header("location:index2.php?side=opret");
} else {
    if($brugernavn == "" || $password == "") {
        echo "$form";
        echo "<div class='red'>Begge felter skal udfyldes</div>";
    } else {
        $fejl = "<div class='red'>Brugernavn eller adgangskode er forkert</div>";

        mysql_connect("localhost", "root");
        mysql_select_db("feely");
       
        $result_user = mysql_query("SELECT brugernavn FROM users WHERE brugernavn = '$brugernavn'") or die(mysql_error());
        $number_user = mysql_num_rows($result_user);

        if($number_user < 1) {           
            echo "$form";
            echo "$fejl";
        } else {
            $result_pw = mysql_query("SELECT password FROM users WHERE brugernavn = '$brugernavn'") or die(mysql_error());
            $row = mysql_fetch_assoc($result_pw);
            $pw = $row['password'];
                       
            if(empty($pw)) {
                echo "$form";
                echo "$fejl";
            } else {
                $_SESSION['user'] = $brugernavn;
                $_SESSION['id'] = $row['id'];
            }
        }
    }
}



?>
Avatar billede chries Nybegynder
24. marts 2004 - 15:45 #1
if(empty($pw)) {
                echo "$form";
                echo "$fejl";
            } else {
->
            if($pw == $password) {
                echo "$form";
                echo "$fejl";
            } else {
Avatar billede engaai Nybegynder
24. marts 2004 - 15:46 #2
nåh ja, glemte helt at sammenligne med det password brugeren indtastede. Tak

Du lægger bare et svar
Avatar billede chries Nybegynder
24. marts 2004 - 15:46 #3
bre ville måske være:

$result_user = mysql_query("SELECT brugernavn, password FROM users WHERE brugernavn = '$brugernavn' AND password='$password'") or die(mysql_error());
        $number_user = mysql_num_rows($result_user);

        if($number_user < 1) {           
            echo "$form";
            echo "$fejl";
        } else {
          // user ok
        }
Avatar billede chries Nybegynder
24. marts 2004 - 15:47 #4
ok =)
Avatar billede chries Nybegynder
24. marts 2004 - 15:48 #5
det skulle foresten være :)

            if($pw != $password) {
                echo "$form";
                echo "$fejl";
            } else
Avatar billede engaai Nybegynder
24. marts 2004 - 15:48 #6
ja men med den anden metode kan man finde ud af om det er passwordet eller brugernavnet der er forket. Men som du siger er det du skriver lang mere logisk
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester