Registrierscript - Deutlich erklären

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

  • Registrierscript - Deutlich erklären

    Hallo,

    ich hab mit ein Registrierscript gebastelt nur leider funktioniert das nicht ganz so wie es eigentlich sollte. Eigentlich funktioniert garnicht :/. Ich hab erstmal das grundgerüst gemacht so wie ich denke das es geht und funktionieren sollte. Ich will derweil noch keine Sicherheits und Verbesserungsvorschläge sondern erstmal das es so geht und man sich registrieren kann. Alles andere mach ich später.

    Da ich mich aber noch relativ als Anfänger einschätze möchte ich das ihr mir das bitte leicht verständlich erklärt, weil ich kenne das von anderen Foren wo dann die PHP Profis kommen mit irgendwelchen Fachwörtern nur um den anderen zu zeigen wie toll se nicht sind in der Sprache PHP. Naja hoffe mir können ein paar helfen (Gute Erklärung brauch man halt sonst nützt es alles nix )

    Hier die index.php:

    PHP-Code:
    <HTML>
    <form method="post" action="<?php $_SERVER['PHP_SELF'?>" style="display:inline;">
    <table width="99%" border="0" align="center" cellpadding="1" cellspacing="1">
    <tr>
    <td width="21%" bgcolor="#FFFFFF" class="table">Username:</td>
    <td width="79%" bgcolor="#FFFFFF">
    <input name="username" type="text" class="formLogin" style="width: 100%" id="username">
    </td>
    </tr>
    <tr>
    <td bgcolor="#FFFFFF" class="table">E-Mail:</td>
    <td bgcolor="#FFFFFF">
    <input name="email" type="text" class="formLogin" id="email" style="width: 100%">
    </td>
    </tr>
    <tr>
    <td bgcolor="#FFFFFF" class="table">Password:</td>
    <td bgcolor="#FFFFFF">
    <input name="password" type="password" class="formLogin" id="password" style="width: 100%" value="">
    </td>
    </tr>
    <tr>
    <td bgcolor="#FFFFFF" class="table">Confirm password: </td>
    <td bgcolor="#FFFFFF">
    <input name="confirm" type="password" class="formLogin" id="confirm" style="width: 100%">
    </td>
    </tr>
    <tr>
    <td colspan="2" bgcolor="#FFFFFF">
    <input name="register" type="submit" class="formSubmitLogin" id="register" 
    style="width: 100%" value="Submit">
    </td>
    </tr>
    </table></form>

    <?php
        
    if($_POST['register']) {

        
    $username=$_POST['username'];
        
    $email=$_POST['email'];
        
    $password=$_POST['password'];
        
    $confirm=$_POST['confirm'];
        
        
        if(
    $username=""
    die (
    "Please enter an username.");
        if(
    $email=""
    die (
    "Please enter an email address.");
        if(
    $password=""
    die (
    "You have to enter a password.");
        if(
    $confirm=""
    die (
    "You have to confirm you password.");
        if(
    $confirm != $password
    die (
    "Your confirmed password does not match with you password.");
        
        
    $pass=md5($confirm);
        
        
    mysql_query("INSERT INTO `users` VALUES (username='$username',email='$email',password='$pass')");
        
        
    redirect('../register/''Your registration has been sucessfull');
    }
    else {
        
    redirect("../register/""Sorry but there are some errors. Please contact our webmaster.");
    }
    ?>
    So danke schon mal im vorraus

    //edit: Sorry habs zuspät gelesen das mit dem Zeilenumbruch bei HTML Codes :X
    Zuletzt geändert von Lion.BeN; 02.11.2006, 20:00.

  • #2
    Re: Registrierscript - Deutlich erklären

    Regeln lesen, Code umbrechen.
    I don't believe in rebirth. Actually, I never did in my whole lives.

    Kommentar


    • #3
      Hi,

      Du solltest uns auch noch erzählen, was denn nicht funktioniert. Was soll passieren, was passiert stattdessen?
      Und die Regeln auch noch mal bzgl. Fehlerausgabe lesen.
      Auf den ersten Blick: Die Syntax Deines SQL-Statements ist falsch. Wie es richtig aussehen muss, findest Du hier.
      Auch sonst ein schönes Tutorial für Anfänger.

      LG
      EDIT:
      Ausserdem vermisse ich auch einen Verbindungsaufbau zur Datenbank. Findest Du auch im Tutorial.
      Zuletzt geändert von kuddeldaddeldu; 02.11.2006, 16:51.

      Kommentar


      • #4
        Also das Script soll bei richtiger Ausführung den User in der Datenbank adden und Fehler anzeigen, wenn kein Username, keine E-Mail Adresse, kein Passwort oder das wiederholte Passwort nicht eingegeben wurde, bzw. das wiederholte Passwort nicht mit dem Passwort übereinstimmt.


        Ich hab vorher ein Include in der Datei wo du functions.php included wird, in der error_reporting(E_ALL); steht.

        Das Script hat bisher nichts gemacht. Also wenn ich auf Registrieren klick dann gibt er mir weder ne Fehlermeldung noch fügt er den User in die Datenbank hinzu.

        Des Weiteren bekomme ich ein Fatal Error der so heißt:

        Fatal error: Call to undefined function redirect() in D:\Program Files\xampp\htdocs\lion\register\index.php on line 121


        EDIT// Ok nun hab ich den MYSQL Fehler behoben und er fügt den User in die Datenbank nur leider macht er da irgendwas falsch :X. Er fügt den Usernamen und die E-Mail nicht ein und das Passwort ist völlig falsch.

        Achja ich hab vergessen zu erwähnen das der User nach erfolgreichem registrieren weitergeleitet werden soll auf die Page mit der Nachricht die oben im Quelltext steht.
        Zuletzt geändert von Lion.BeN; 02.11.2006, 17:24.

        Kommentar


        • #5
          Hat keiner eine Idee oder wird mein Post grad ignoriert wegen der Bild Verzerrung?

          Kommentar


          • #6
            PHP-Code:

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

                
            $username=$_POST['username'];
                
            $email=$_POST['email'];
                
            $password=$_POST['password'];
                
            $confirm=$_POST['confirm'];
                
                
                if(
            $username="") die ("Please enter an username.");
                if(
            $email="") die ("Please enter an email address.");
                if(
            $password="") die ("You have to enter a password.");
                if(
            $confirm="") die ("You have to confirm you password.");
                if(
            $confirm != $password) die ("Your confirmed password does not match with you password.");
                
                
            $pass=md5($confirm);
                
                
            mysql_connect(...) or die (...);
                
            mysql_select_db(...) or die (...);
                
                
            mysql_query("INSERT INTO users (username, email, password) 
            VALUES ('"
            .$username."','".$email."','".$password."')");
                
                
            header('location: ....');
            }
            else {
                
            header('location: ....');

            so könnte es aussehen. die ... musste selber ergänzen.
            bei header('location') muss http am anfang stehen.
            gruss
            Zuletzt geändert von Malaga; 02.11.2006, 20:34.

            Kommentar


            • #7
              PHP-Code:
                if($username=""
              // brav, wenn du username einen leeren string erfolgreich zuweist, dann stirb bitte ôÔ
              die ("Please enter an username.");
                  if(
              $email=""
              die (
              "Please enter an email address.");
                  if(
              $password=""
              die (
              "You have to enter a password.");
                  if(
              $confirm=""
              die (
              "You have to confirm you password.");
                  if(
              $confirm != $password
              die (
              "Your confirmed password does not match with you password.");
                  
                  
              $pass=md5($confirm); 
              lass mich raten, du gibts 'abc' als PW ein un am ende stehen dort 32 zeichen die mit 'abc' gaaaaar nix zu tun haben ?
              PHP Forum
              Sessions in PHP
              Loginsystem mit PHP erstellen

              Kommentar


              • #8
                nein keine angst ich weis das die md5 verschlüsselt sidn und nun funzt alles. ok ich hab in einem anderen forum nen anderen tipp bekommen. also bisher funzt nun alles und der Code sieht vollgendermaßen aus:

                PHP-Code:
                <?php
                    
                if(isset($_POST['register'])) {

                    
                $username=$_POST['username'];
                    
                $email=$_POST['email'];
                    
                $password=$_POST['password'];
                    
                $confirm=$_POST['confirm'];
                    
                $id=$_POST['id'];
                    
                    
                    if(
                $username=="") die ("Please enter an username.");
                    if(
                $email=="") die ("Please enter an email address.");
                    if(
                $password=="") die ("You have to enter a password.");
                    if(
                $confirm=="") die ("You have to confirm you password.");
                    if(
                $confirm != $password) die ("Your confirmed password does not match with you password.");
                    
                    
                $pass=md5($confirm);
                    
                    
                mysql_query("INSERT INTO `users` (id,username,email,password) VALUES ('$id','$username','$email','$pass')") or die("Fehler: ".mysql_error());
                    
                    
                printf("<script language =\"JavaScript\">document.location.href =\"../register/\";</script>");
                }
                else {
                    
                printf("<script language =\"JavaScript\">document.location.href =\"../register/\";</script>");
                }
                ?>
                Leider weiß ich nicht genau was der unterschied zwischen printf und print ist und was printf bringt. Naja desweiteren soll bei erfolgreichem registrieren der user auf die register seite (../register/) weitergeleitet werden und dort eine Nachricht wie "Successfully registered" bekommen wie kann ich das dort realisieren?

                und die errors werden bei mir UNTER dem design angezeigt sollen aber in dem content bereich stehen wie kann ich das verwirklichen?

                Kommentar


                • #9
                  Original geschrieben von Lion.BeN Leider weiß ich nicht genau was der unterschied zwischen printf und print ist und was printf bringt.
                  rtfm: www.php.net

                  und die errors werden bei mir UNTER dem design angezeigt sollen aber in dem content bereich stehen wie kann ich das verwirklichen?
                  indem du die fehlermeldungen dort ausgibst, wo sie benötigt werden.
                  dazu würde es sich anbieten, das formular vor der html-ausgabe zu prüfen. und entsprechende fehlervariablen zu füllen. ist alles ok - weiterleitung mit php (header() mit der url und als get-parameter der username) nicht mit js.
                  wenn nicht ok - formular mit den generierten fehlermeldungen anzeigen.

                  Naja desweiteren soll bei erfolgreichem registrieren der user auf die register seite (../register/) weitergeleitet werden und dort eine Nachricht wie "Successfully registered" bekommen wie kann ich das dort realisieren?
                  so, wenn du weitergeleitet hast, steht dir der username als get-parameter zur verfügung - einfach die db auslesen und echo 'Successfully registered' ausgeben.
                  das sollte immer erfolgreich sein, da du sinnvollerweise vor der weiterleitung überprüft hast, ob der neue account aufgrund der formulardaten erstellt werden konnte.

                  Kommentar

                  Lädt...
                  X