Here is the registration form:
| <formid='register'action='register.php'method='post'    accept-charset='UTF-8'><fieldset><legend>Register</legend><inputtype='hidden'name='submitted'id='submitted'value='1'/><labelfor='name'>Your Full Name*: </label><inputtype='text'name='name'id='name'maxlength="50"/><labelfor='email'>Email Address*:</label><inputtype='text'name='email'id='email'maxlength="50"/><labelfor='username'>UserName*:</label><inputtype='text'name='username'id='username'maxlength="50"/><labelfor='password'>Password*:</label><inputtype='password'name='password'id='password'maxlength="50"/><inputtype='submit'name='Submit'value='Submit'/></fieldset></form> | 
Form validation
At this point it is a good idea to put some form validation code in place, so we make sure that we have all the data required to create the user account. We need to check if name and email, and password are filled in and that the email is in the proper format.We can use the free JavaScript form validation script to add form validations quickly and easily, with lesser code.
Here is a sample JavaScript validation code to be used for the sample form we created earlier:
| varfrmvalidator  = newValidator("register");frmvalidator.EnableOnPageErrorDisplay();frmvalidator.EnableMsgsTogether();frmvalidator.addValidation("name","req","Please provide your name");frmvalidator.addValidation("email","req","Please provide your email address");frmvalidator.addValidation("email","email","Please provide a valid email address");frmvalidator.addValidation("username","req","Please provide a username");frmvalidator.addValidation("password","req","Please provide a password"); | 
Handling the form submission
Now we have to handle the form data that is submitted.Here is the sequence (see the file fg_membersite.php in the downloaded source):
| functionRegisterUser(){    if(!isset($_POST['submitted']))    {       returnfalse;    }        $formvars= array();        if(!$this->ValidateRegistrationSubmission())    {        returnfalse;    }        $this->CollectRegistrationSubmission($formvars);        if(!$this->SaveToDatabase($formvars))    {        returnfalse;    }        if(!$this->SendUserConfirmationEmail($formvars))    {        returnfalse;    }    $this->SendAdminIntimationEmail($formvars);        returntrue;} | 
Saving the data in the database
Now that we gathered all the data, we need to store it into the database.Here is how we save the form submission to the database.
| functionSaveToDatabase(&$formvars)   {       if(!$this->DBLogin())       {           $this->HandleError("Database login failed!");           returnfalse;       }       if(!$this->Ensuretable())       {           returnfalse;       }       if(!$this->IsFieldUnique($formvars,'email'))       {           $this->HandleError("This email is already registered");           returnfalse;       }              if(!$this->IsFieldUnique($formvars,'username'))       {           $this->HandleError("This UserName is already used. Please try another username");           returnfalse;       }               if(!$this->InsertIntoDB($formvars))       {           $this->HandleError("Inserting to Database failed!");           returnfalse;       }       returntrue;   } | 
After logging in, we make sure that the table is existing.(If not, the script will create the required table).
Then we make sure that the username and email are unique. If it is not unique, we return error back to the user.
The database table structure
This is the table structure. The CreateTable() function in the fg_membersite.php file creates the table. Here is the code:| functionCreateTable(){    $qry= "Create Table $this->tablename (".            "id_user INT NOT NULL AUTO_INCREMENT ,".            "name VARCHAR( 128 ) NOT NULL ,".            "email VARCHAR( 64 ) NOT NULL ,".            "phone_number VARCHAR( 16 ) NOT NULL ,".            "username VARCHAR( 16 ) NOT NULL ,".            "password VARCHAR( 32 ) NOT NULL ,".            "confirmcode VARCHAR(32) ,".            "PRIMARY KEY ( id_user )".            ")";                if(!mysql_query($qry,$this->connection))    {        $this->HandleDBError("Error creating the table \nquery was\n $qry");        returnfalse;    }    returntrue;} | 
Inserting the registration to the table
Here is the code that we use to insert data into the database. We will have all our data available in the$formvars array.| functionInsertIntoDB(&$formvars){    $confirmcode= $this->MakeConfirmationMd5($formvars['email']);    $insert_query= 'insert into '.$this->tablename.'(            name,            email,            username,            password,            confirmcode            )            values            (            "' . $this->SanitizeForSQL($formvars['name']) . '",            "' . $this->SanitizeForSQL($formvars['email']) . '",            "' . $this->SanitizeForSQL($formvars['username']) . '",            "' . md5($formvars['password']) . '",            "' . $confirmcode . '"            )';          if(!mysql_query( $insert_query,$this->connection))    {        $this->HandleDBError("Error inserting data to the table\nquery:$insert_query");        returnfalse;    }            returntrue;} | 
Also, we make the unique confirmation code from the user’s email address.
Sending emails
Now that we have the registration in our database, we will send a confirmation email to the user. The user has to click a link in the confirmation email to complete the registration process.| functionSendUserConfirmationEmail(&$formvars){    $mailer= newPHPMailer();        $mailer->CharSet = 'utf-8';        $mailer->AddAddress($formvars['email'],$formvars['name']);        $mailer->Subject = "Your registration with ".$this->sitename;    $mailer->From = $this->GetFromAddress();                $confirmcode= urlencode($this->MakeConfirmationMd5($formvars['email']));        $confirm_url= $this->GetAbsoluteURLFolder().'/confirmreg.php?code='.$confirmcode;        $mailer->Body ="Hello ".$formvars['name']."\r\n\r\n".    "Thanks for your registration with ".$this->sitename."\r\n".    "Please click the link below to confirm your registration.\r\n".    "$confirm_url\r\n".    "\r\n".    "Regards,\r\n".    "Webmaster\r\n".    $this->sitename;    if(!$mailer->Send())    {        $this->HandleError("Failed sending registration confirmation email.");        returnfalse;    }    returntrue;} | 
Note that we make the confirmation URL point to confirmreg.php?code=XXXX (where XXXX is the confirmation code).
