Loginscript geht nicht

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • Loginscript geht nicht

    Hi all
    Ich wollte ein Loginscript für meine Website erstellen. As es dann noch zuviel Fehler hatte,
    nahm ich ein ähnliches Tutorial um die gröbsten Fehler zu ändern. Nun gibt es jedoch immer noch eine Fehlermeldung bei dir ich anstehe. Sobald man sich registrieren will kommt die Fehlermeldung:

    Warning: mysql_fetch_object(): supplied argument is not a valid MySQL result resource in http://URL meines Hosts/indexfuerlogin.php.com on line 99
    doch darunter steht:
    Erfolgreich angemeldet! Sie können sich nun einloggen:
    der Quellcode für die Site is:
    PHP-Code:
    <? 

    # hier kommt der header rein


    if      ($anmelden) { anmelden($fertig, $user, $password1, $password2, $email);}
    else if ($abmelden) { abmelden($fertig, $user, $password);}
    else if ($forgot)   { forgot($fertig, $email);}
    else                { login($fertig, $user, $password);}


    # hier der footer

    ?>



    <?
    function inhalt($user) 
    {
    session_start();
    session_register("user");


    ?>

    <?

    #hier kommt dann der geschützte inhalt....

    echo "Geschützter Inhalt"

    ?>
        
    <?


    }
    ?>



    <?
    function login($fertig, $user, $password)
    {
    include("config.php");

    if ($fertig) {

    $abfrage = mysql_query ("SELECT * FROM login WHERE user = '$user'");
    $reihen = mysql_num_rows($abfrage);
    if ($reihen <= 0) {
    echo "Unbekannter Benutzername!";
    }
    else {
    while ($row = mysql_fetch_object ($abfrage)) {
    if ($row->password==$password) {
    inhalt($user);
    }
    else {
    echo "Falsches Passwort!";
    }
    }
    }

    }

    else {
    echo "Zum registrieren geht es <a href=\"$PHP_SELF?anmelden=yes\">hier</a> lang!";
    echo "<p><h2>Login</h2></p>";

        echo "<form method=\"POST\" action=\"$PHP_SELF?fertig=yes\">";
        ?>
        <table cellspacing="1" cellpadding="2" border="0">
        <tr>
        <td><font size="2">Benutzername:</font></td>
        <td><font size="2"><input type="text" name="user" value="Nick">&nbsp;</font></td>
      </tr>
      <tr>
        <td><font size="2">Passwort:</font></td>
        <td><font size="2"><input type="password" name="password" value="pass"></font></td>
      </tr>
      <tr>
        <td colspan=2 align=center><input type=submit value=Login></td>
      </tr>
    </table>
    </form>
    <? 
    echo "<p><a href=\"$PHP_SELF?forgot=yes\">Passwort vergessen?</a><br><a href=\"$PHP_SELF?abmelden=yes\">Abmelden</a></p>";
    }

    }
    ?>


    <?
    function anmelden ($fertig, $user, $password1, $password2, $email)
    {
    include("config.php");

    if($fertig) {
     $abfrage1 = mysql_query("SELECT user FROM login");
     while ($row = mysql_fetch_object ($abfrage1)) {
        if    ($row->user==$user) {
        echo "Dieser Benutzer existiert schon!";
        exit;
        }
        }
        if ($user=="" OR $password1=="" OR $password2=="" or $email=="") {
        echo "Sie haben mindestens ein Feld nicht ausgefüllt!";
        }
        else if ($password1!=$password2) {
        echo "Ihr Passwort ist ungleich Ihrer Wiederholung!";
        }
        else {    
        $anfuegen=mysql_query("INSERT INTO login (user, password, email) VALUES ('$user','$password1', '$email')");    
        echo "Erfolgreich angemeldet! Sie können sich nun einloggen:<br>";
        @login();    
        }
    }
    else {
        echo "<h2>Registrieren</h2>";
        echo "<form method=\"POST\" action=\"$PHP_SELF?anmelden=yes&fertig=yes\">";
        ?>
        <table cellspacing="1" cellpadding="2" border="0">
        <tr>
        <td><font size="2">Benutzername:</font></td>
        <td><font size="2"><input type="text" name="user" value="Nick">&nbsp;</font></td>
      </tr>
      <tr>
        <td><font size="2">Passwort:</font></td>
        <td><font size="2"><input type="password" name="password1" value="pass"></font></td>
      </tr>
      <tr>
        <td><font size="2">Wiederholen:</font></td>
        <td><font size="2"><input type="password" name="password2" value="pass"></font></td>
      </tr>
      <tr>
        <td><font size="2">E-Mail:</font></td>
        <td><font size="2"><input type="text" name="email" value="@">&nbsp;</font></td>
      </tr>
      <tr>
        <td colspan=2 align=center><input type=submit value=Anmelden></td>
      </tr>
    </table>
    </form>

    <? 
    }

    }
    ?>




    <?
    function forgot ($fertig, $email)
    {

    include("config.php");

    if ($fertig) {
    $abfrage=mysql_query("SELECT * FROM login");
    while ($row = mysql_fetch_object ($abfrage)) {
    if ($email==$row->email) { $ismail="true"; } 
    }
    if ($ismail=="true") {
    $password=mysql_query("SELECT * FROM login WHERE email = '$email'");
    while ($row = mysql_fetch_object ($password)) {
    $nachricht="Hallo $row->user!\n\nIhr Passwort ist:\n\n$row->password\n\nMfG\nAdmin";
    }
    mail($email, "Passwort", $nachricht, "From: Administrator");
    ?>
    <p>Das Passwort wurde Ihnen erfolgreich an die Adresse <i><? echo $email; ?></i> geschickt!<br>
    Rufen Sie Ihre E-Mails ab und loggen Sie sich ein.<br></p>

    <?

    @login();
    }
    else { echo "Ihre angegebene E-Mail Adresse wurde nicht gefunden!";}
    }
    else {

    echo "<p><h2>Passwort vergessen</h2><p>";
    echo "<p><form method=post action=\"$PHP_SELF?forgot=yes&fertig=yes\">";
    ?>
    <table cellspacing="1" cellpadding="2" border="0">
    <tr><td><font size="2">E-Mail Adresse:</font></td><td align=center><input type=text name=email value="@"></td></tr>
    <tr><td colspan="2" align=center><input type=submit value="Schicken!"></td></tr>
    </table></form></p>
    <?
    }
    }
    ?>



    <?
    function abmelden($fertig, $user, $password)
    {

    include ("config.php");

    if($fertig) {
    $abfrage = mysql_query ("SELECT * FROM login WHERE user = '$user'");
    $reihen = mysql_num_rows($abfrage);
    if ($reihen <= 0) {
    echo "Unbekannter Benutzername!";
    }
    else {
    while ($row = mysql_fetch_object ($abfrage)) {
    if ($row->password==$password) {
    $delete = mysql_query ("DELETE FROM login WHERE user = '$user'");
    echo "Ihre Daten wurden erfolgreich aus der Datenbank entfernt!";
    }
    else {
    echo "Falsches Passwort!";
    }
    }
    }

    }
    else {
         echo "<p><h2>Abmelden</h2></p>"; 
        echo "<form method=\"POST\" action=\"$PHP_SELF?abmelden=yes&fertig=yes\">";
        ?>
        <table cellspacing="1" cellpadding="2" border="0">
        <tr>
        <td><font size="2">Benutzername:</font></td>
        <td><font size="2"><input type="text" name="user" value="Nick">&nbsp;</font></td>
      </tr>
      <tr>
        <td><font size="2">Passwort:</font></td>
        <td><font size="2"><input type="password" name="password" value="pass"></font></td>
      </tr>
      <tr>
        <td colspan=2 align=center><input type=submit value=Abmelden></td>
      </tr>
    </table>
    </form>
    <?
    }

    }
    ?>
    Ich habe bereits versucht die array einzubauen aber das geht auch nicht...
    Die Datei config.php hab ich und sie funktioniert einwandfrei. das einzige Problem ist das wegen dem E-Mail....
    solltet ihr noch Fragen haben beantworte ich sie euch gerne ihr müsst jedoch wissen das ich erst seit kurzem PHP programmiere und darum noch nicht allzu viel weiss (d.h. ich kann schon einigermassen html, javascript und C++ programmieren)

    Bitte helft mir !!
    mfg Teran
    Zuletzt geändert von Teran; 12.10.2006, 13:29.

  • #2
    verwende bei deinen mysql_query() mal ein or die(mysql_error());

    beispiel: mysql_query("SELECT spalte FROM table") or die(mysql_error());
    Sunshine CMS
    BannerAdManagement
    Borlabs - because we make IT easier
    Formulargenerator [color=red]Neu![/color]
    Herkunftsstatistik [color=red]Neu![/color]

    Kommentar


    • #3
      Yo 1.danke für den Tipp!
      2.jetzt kommt eine neue fehlermeldung wenn ich mich nämlich registrieren will und anklicke das es mir ein mail mit den zugangs daten schicken soll kommt die fehler meldung:

      Table 'teran.login' doesn't exist

      ich finde das komisch ich habe noch nie eine solche Fehlermedlung gesehen es steht einfach nur:
      Table 'teran.login' doesn't exist
      und sonst nichts.... könnt ihr mir helfen?

      Kommentar


      • #4
        Original geschrieben von Teran
        ich finde das komisch ich habe noch nie eine solche Fehlermedlung gesehen es steht einfach nur:
        Table 'teran.login' doesn't exist
        und sonst nichts.... könnt ihr mir helfen?
        Hilf dir selbst - was bedeutet das denn wohl auf Deutsch ...?

        Richtig, in deiner Datenbank teran existiert keine Tabelle mit dem Namen login.
        I don't believe in rebirth. Actually, I never did in my whole lives.

        Kommentar

        Lädt...
        X