• Jetzt anmelden. Es dauert nur 2 Minuten und ist kostenlos!

PHP Login

SimoNxD

Mitglied
Und ein weiteres mal Hallo Leute ;o.
Wie immer habe ich ein Problem, diesmal mit dem Login...

PHP:
<?PHP
 
  if(isset($_POST['submit']) && ($_POST['submit']=="login" || $_POST['submit']=="LOGIN"))
  {
    if(!empty($_POST['userid']) && !empty($_POST['userpass']) && checkAnum($_POST['userid']) && checkAnum($_POST['userpass']))
    {
      $sqlCmd = "SELECT id,login,coins,web_admin,email
      FROM account.account
      WHERE login
      LIKE '".mysqli_real_escape_string($_POST['userid'])."'
      AND password=PASSWORD('".mysql_real_escape_string($_POST['userpass'])."')
      LIMIT 1";
      $sqlQry = mysql_query($sqlCmd,$db_game);
      if(mysql_num_rows($sqlQry)>0)
      {
        $getAdmin = mysql_fetch_object($sqlQry);
        $_SESSION['user_id'] = $getAdmin->id;
        $_SESSION['user_name'] = $getAdmin->login;
        $_SESSION['user_admin'] = $getAdmin->web_admin;
        $_SESSION['user_coins'] = $getAdmin->coins;
        $_SESSION['user_email'] = $getAdmin->email;
        $updateIP = mysql_query("UPDATE account.account SET web_ip='".mysqli_real_escape_string($_SERVER['REMOTE_ADDR'])."' WHERE id='".mysql_real_escape_string($getAdmin->id)."'",$db_game);
       
      }
    }
  }

  if(empty($_SESSION['user_id']))
  {
    unset($_SESSION['user_id']);
    unset($_SESSION['user_name']);
    unset($_SESSION['user_admin']);
    unset($_SESSION['user_coins']);
    unset($_SESSION['user_email']);
  }
  else {
    $sqlCmd = "SELECT id,login,web_admin,coins,email FROM account.account WHERE web_ip='".mysql_real_escape_string($_SERVER['REMOTE_ADDR'])."' AND id='".mysql_real_escape_string($_SESSION['user_id'])."' LIMIT 1";
    $sqlQry = mysql_query($sqlCmd,$db_game);
    if(mysql_num_rows($sqlQry)>0)
    {
      $getAdmin = mysqli_fetch_object($sqlQry);
      $_SESSION['user_id'] = $getAdmin->id;
      $_SESSION['user_name'] = $getAdmin->login;
      $_SESSION['user_admin'] = $getAdmin->web_admin;
      $_SESSION['user_coins'] = $getAdmin->coins;
      $_SESSION['user_email'] = $getAdmin->email;
     
    }
    else
    {
        unset($_SESSION['user_id']);
        unset($_SESSION['user_name']);
        unset($_SESSION['user_admin']);
        unset($_SESSION['user_coins']);
        unset($_SESSION['user_email']);
    }
  }
 

?>

ein äußerst langer login script ich weis ;o.
Aber zum Fehler...
Wenn ich meine Daten eingebe, passiert NICHTS. er aktualisiert die Seite, aber das wars, es wird keine Fehlermeldung o.Ä. ausgespuckt...

Woran kann es liegen ;o?
 
HTML:
  <form action="?s=login" method="post">
             <input type="text" class="user" name="userid" value="Benutzername" onfocus="ValueChange('Benutzername', this);" onblur="ValueChange('Benutzername', this);" />
       <input type="password" name="userpass" class="password" maxlength="16" value="xxxxxxxxxxx" onfocus="ValueChange('xxxxxxxxxxx', this);" onblur="ValueChange('xxxxxxxxxxx', this);" />
             <input type="submit" name="submit" value="login">
           <div class="clearfix"></div>
           </form>
 
Hallo,

und was hälst da von mal einfach zu debugen, nach jeder if abfrage einfach mal ein
PHP:
echo "geschaft#1";
und immer +1 um zu schauen bis wo funktioniert und ab wann die ausgabe fehlt um den fehler zu finden?

Denn auf die schnelle sehe ich jetzt kein fehler, was aber nicht viel zu sagen hat.

Cheffchen
 
Das bessere Debugging:

Richtig debuggen

1. Man bemerkt, dass ein Skript nicht das tut, was es soll.
2. Man schreibt an den Anfang des Scriptes die Zeile: error_reporting(-1);
3. Man verwendet ini_set('display_errors', true); damit die Fehler auch angezeigt werden.
4. Man versucht, die Stelle die daran Schuld sein kann, schonmal einzugrenzen. Falls dies nicht geht, wird zunächst das komplette Skript als fehlerhaft angesehen.
5. An markanten Stellen im Skript lässt man sich wichtige Variableninhalte ausgeben und ggf. auch in bedingten Anweisungen eine kurze Ausgabe machen, um zu überprüfen, welche Bedingung ausgeführt wurde. Wichtig bei MySQL Fehlern (...not a valid MySQL result resource...): mysqli_error() verwenden oder Abfrage ausgeben und zb mit phpmyadmin testen.
6. Schritt 5 wird so lange wiederholt, bis Unstimmigkeiten im Skript auffallen
7. Damit hat man das Problem (Unstimmigkeit) gefunden und kann versuchen diese zu beheben. Hierzu dienen dann die PHP-Dokumentation und andere Quellen als Ratgeber.
8. Lässt sich das konkrete Problem trotzdem nicht beheben, kann man in Foren um Rat fragen.
9. Das Programm läuft und man kann die Debug-Ausgaben wieder entfernen.
 
Zurück
Oben