Sign up Form with Email Verification in PHP/MySQLi Tutorial

Language

This tutorial will teach you how to send email/verification email in PHP/MySQLi using the mail() function. The function will both work in local server(ex. XAMMP) or hosted server(online) but in case you wanted to send an email via the local server, you need to modify your local server to allow it to send an email. In my case, I'm using XAMMP, so, I'm going to show you how to set up your XAMMP to send an email.

Setting up Local Server to Send Email

Configure php.ini
  1. Open php.ini in C:\xampp\php\php.ini.
  2. Find extension=php_openssl.dll and remove the semicolon from the beginning of that line.
  3. Find [mail function], enable the ff. by removing the semicolon at the start of the line then, change their values:
    • SMTP=smtp.gmail.com
    • smtp_port=465
    • sendmail_from = ndevierte@gmail.com
    • sendmail_path = "C:\xampp\sendmail\sendmail.exe -t"
php.ini Configure sendmail.ini
  1. Open sendmail.ini in C:\xampp\sendmail\sendmail.ini
  2. Find [sendmail], enable the ff. by removing the semicolon at the start of the line, then change their values:
    • smtp_server=smtp.gmail.com
    • smtp_port=465
    • auth_username=ndevierte@gmail.com
    • auth_password=yourpassword
    • force_sender=ndevierte@gmail.com
sendmail.ini sendmail.ini2

Lastly. make sure to turn this on to allow XAMMP to send an email to your email. Use this link.

And you're done. Restart XAMMP and you should now be able to send email using your XAMMP.

Working Example

To test if your XAMMP is working, here's our example. We will create a registration with a verification email.

NOTE: Scripts and CSS used in this tutorial are hosted, so, you might need an internet connection for them to work.

Creating our Database

The first step is to create our database.
  1. Open phpMyAdmin.
  2. Click databases, create a database and name it as sample.
  3. After creating a database, click the SQL and paste the below codes. See the image below for detailed instructions.
  1. CREATE TABLE `user` (
  2.   `userid` INT(11) NOT NULL AUTO_INCREMENT,
  3.   `email` VARCHAR(50) NOT NULL,
  4.   `password` VARCHAR(50) NOT NULL,
  5.   `code` VARCHAR(20) NOT NULL,
  6.   `verify` INT(1) NOT NULL,
  7. PRIMARY KEY(`userid`)
  8. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
sendmail

Creating our Connection

Next, we create our connection to our database. This will serve as the bridge between our forms and database. We name this as conn.php.

  1. <?php
  2.  
  3. $conn = mysqli_connect("localhost","root","","sample");
  4. if (!$conn) {
  5.         die("Connection failed: " . mysqli_connect_error());
  6. }
  7.  
  8. ?>
index.php

This contains our login form but you can access a link here if you want to sign up.

  1. <?php
  2.         session_start();
  3.         include('conn.php');
  4.  
  5.         if(isset($_SESSION['id'])){
  6.                 header('location:home.php');
  7.         }
  8. ?>
  9.  
  10. <!DOCTYPE html>
  11. <html>
  12. <head>
  13.         <title>Sign up Form with Email Verification in PHP/MySQLi</title>
  14.         <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
  15.         <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
  16.         <link href="https://fonts.googleapis.com/css?family=Open+San">
  17.         <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
  18.         <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">  
  19. <style>
  20.         #login_form{
  21.                 width:350px;
  22.                 position:relative;
  23.                 top:50px;
  24.                 margin: auto;
  25.                 padding: auto;
  26.         }
  27. </style>
  28. </head>
  29. <body>
  30. <div class="container">
  31.         <div id="login_form" class="well">
  32.                 <h2><center><span class="glyphicon glyphicon-lock"></span> Please Login</center></h2>
  33.                 <hr>
  34.                 <form method="POST" action="login.php">
  35.                 Email: <input type="text" name="email" class="form-control" required>
  36.                 <div style="height: 10px;"></div>              
  37.                 Password: <input type="password" name="password" class="form-control" required>
  38.                 <div style="height: 10px;"></div>
  39.                 <button type="submit" class="btn btn-primary"><span class="glyphicon glyphicon-log-in"></span> Login</button> No account? <a href="signup.php"> Sign up</a>
  40.                 </form>
  41.                 <div style="height: 15px;"></div>
  42.                 <?php
  43.                         if(isset($_SESSION['log_msg'])){
  44.                                 ?>
  45.                                 <div style="height: 30px;"></div>
  46.                                 <div class="alert alert-danger">
  47.                                         <span><center>
  48.                                         <?php echo $_SESSION['log_msg'];
  49.                                                 unset($_SESSION['log_msg']);
  50.                                         ?>
  51.                                         </center></span>
  52.                                 </div>
  53.                                 <?php
  54.                         }
  55.                 ?>
  56.         </div>
  57. </div>
  58. </body>
  59. </html>
signup.php

This is our sign-up form.

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.         <title>Sign up Form with Email Verification in PHP/MySQLi</title>
  5.         <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
  6.         <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
  7.         <link href="https://fonts.googleapis.com/css?family=Open+San">
  8.         <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
  9.         <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
  10. <style>
  11.         #signup_form{
  12.                 width:350px;
  13.                 position:relative;
  14.                 top:50px;
  15.                 margin: auto;
  16.                 padding: auto;
  17.         }
  18. </style>
  19. </head>
  20. <body>
  21. <div class="container">
  22.         <div id="signup_form" class="well">
  23.                 <h2><center><span class="glyphicon glyphicon-user"></span> Sign Up</center></h2>
  24.                 <hr>
  25.                 <form method="POST" action="register.php">
  26.                 Email: <input type="text" name="email" class="form-control" required>
  27.                 <div style="height: 10px;"></div>              
  28.                 Password: <input type="password" name="password" class="form-control" required>
  29.                 <div style="height: 10px;"></div>
  30.                 <button type="submit" class="btn btn-primary"><span class="glyphicon glyphicon-save"></span> Sign Up</button> <a href="index.php"> Back to Login</a>
  31.                 </form>
  32.                 <?php
  33.                         session_start();
  34.                         if(isset($_SESSION['sign_msg'])){
  35.                                 ?>
  36.                                 <div style="height: 40px;"></div>
  37.                                 <div class="alert alert-danger">
  38.                                         <span><center>
  39.                                         <?php echo $_SESSION['sign_msg'];
  40.                                                 unset($_SESSION['sign_msg']);
  41.                                         ?>
  42.                                         </center></span>
  43.                                 </div>
  44.                                 <?php
  45.                         }
  46.                 ?>
  47.                
  48.         </div>
  49. </div>
  50. </body>
  51. </html>
register.php

This contains our signup code as well as our send verification email code.

  1. <?php
  2.         include('conn.php');
  3.         session_start();
  4.  
  5.         if ($_SERVER["REQUEST_METHOD"] == "POST") {
  6.  
  7.         function check_input($data){
  8.                 $data=trim($data);
  9.                 $data=stripslashes($data);
  10.                 $data=htmlspecialchars($data);
  11.                 return $data;
  12.         }
  13.  
  14.         $email=check_input($_POST['email']);
  15.         $password=md5(check_input($_POST['password']));
  16.  
  17.         if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
  18.                 $_SESSION['sign_msg'] = "Invalid email format";
  19.                 header('location:signup.php');
  20.         }
  21.  
  22.         else{
  23.  
  24.                 $query=mysqli_query($conn,"select * from user where email='$email'");
  25.                 if(mysqli_num_rows($query)>0){
  26.                         $_SESSION['sign_msg'] = "Email already taken";
  27.                         header('location:signup.php');
  28.                 }
  29.                 else{
  30.                 //depends on how you set your verification code
  31.                 $set='123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
  32.                 $code=substr(str_shuffle($set), 0, 12);
  33.  
  34.                 mysqli_query($conn,"insert into user (email, password, code) values ('$email', '$password', '$code')");
  35.                 $uid=mysqli_insert_id($conn);
  36.                 //default value for our verify is 0, means it is unverified
  37.  
  38.                 //sending email verification
  39.                 $to = $email;
  40.                         $subject = "Sign Up Verification Code";
  41.                         $message = "
  42.                                 <html>
  43.                                 <head>
  44.                                 <title>Verification Code</title>
  45.                                 </head>
  46.                                 <body>
  47.                                 <h2>Thank you for Registering.</h2>
  48.                                 <p>Your Account:</p>
  49.                                 <p>Email: ".$email."</p>
  50.                                 <p>Password: ".$_POST['password']."</p>
  51.                                 <p>Please click the link below to activate your account.</p>
  52.                                 <h4><a href='http://localhost/send_mail/activate.php?uid=$uid&code=$code'>Activate My Account</h4>
  53.                                 </body>
  54.                                 </html>
  55.                                 ";
  56.                         //dont forget to include content-type on header if your sending html
  57.                         $headers = "MIME-Version: 1.0" . "\r\n";
  58.                         $headers .= "Content-type:text/html;charset=UTF-8" . "\r\n";
  59.                         $headers .= "From: webmaster@sourcecodester.com". "\r\n" .
  60.                                                 "CC: ndevierte@gmail.com";
  61.  
  62.                 mail($to,$subject,$message,$headers);
  63.  
  64.                 $_SESSION['sign_msg'] = "Verification code sent to your email.";
  65.                 header('location:signup.php');
  66.  
  67.                 }
  68.         }
  69.         }
  70. ?>
activate.php

The goto page from registered email. This is our verification page.

  1. <?php
  2.         include('conn.php');
  3.         session_start();
  4.         if(isset($_GET['code'])){
  5.         $user=$_GET['uid'];
  6.         $code=$_GET['code'];
  7.  
  8.         $query=mysqli_query($conn,"select * from user where userid='$user'");
  9.         $row=mysqli_fetch_array($query);
  10.  
  11.         if($row['code']==$code){
  12.                 //activate account
  13.                 mysqli_query($conn,"update user set verify='1' where userid='$user'");
  14.                 ?>
  15.                 <p>Account Verified!</p>
  16.                 <p><a href="index.php">Login Now</a></p>
  17.                 <?php
  18.         }
  19.         else{
  20.                 $_SESSION['sign_msg'] = "Something went wrong. Please sign up again.";
  21.                 header('location:signup.php');
  22.         }
  23.         }
  24.         else{
  25.                 header('location:index.php');
  26.         }
  27. ?>
login.php

Our login code will check if the user has successfully signed up and verified its account.

  1. <?php
  2.         include('conn.php');
  3.         session_start();
  4.        
  5.         if ($_SERVER["REQUEST_METHOD"] == "POST") {
  6.  
  7.                 function check_input($data) {
  8.                 $data = trim($data);
  9.                 $data = stripslashes($data);
  10.                 $data = htmlspecialchars($data);
  11.                 return $data;
  12.                 }
  13.  
  14.                 $email=check_input($_POST['email']);
  15.                 $password=md5(check_input($_POST['password']));
  16.  
  17.                 if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
  18.                         $_SESSION['log_msg'] = "Invalid email format";
  19.                         header('location:index.php');
  20.                 }
  21.                 else{
  22.                         $query=mysqli_query($conn,"select * from user where email='$email' and password='$password'");
  23.                         if(mysqli_num_rows($query)==0){
  24.                                 $_SESSION['log_msg'] = "User not found";
  25.                                 header('location:index.php');
  26.                         }
  27.                         else{
  28.                                 $row=mysqli_fetch_array($query);
  29.                                 if($row['verify']==0){
  30.                                         $_SESSION['log_msg'] = "User not verified. Please activate account";
  31.                                         header('location:index.php');
  32.                                 }
  33.                                 else{
  34.                                         $_SESSION['id']=$row['userid'];
  35.                                         header('location:index.php');
  36.                                 }
  37.                         }
  38.                 }
  39.  
  40.         }
  41. ?>
home.php

This page will show if the user that login is verified.

  1. <!DOCTYPE html>
  2.         <title>Sign up Form with Email Verification in PHP/MySQLi</title>
  3.         <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
  4.         <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
  5.         <link href="https://fonts.googleapis.com/css?family=Open+San">
  6.         <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
  7.         <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">  
  8. </head>
  9.         <div class="container">
  10.                 <h2>Login Successful</h2>
  11.                 <p><a href="logout.php">Logout</a></p>
  12.         </div>
  13. </body>
  14. </html>
logout.php

Lastly, our logout will destroy our login session.

  1. <?php
  2.         session_start();
  3.         session_destroy();
  4.         header('location:index.php');
  5. ?>
DEMO

That ends this tutorial. If you have any questions or comments, feel free to write them below or message me.

Happy Coding :)

Note: Due to the size or complexity of this submission, the author has submitted it as a .zip file to shorten your download time. After downloading it, you will need a program like Winzip to decompress it.

Virus note: All files are scanned once-a-day by SourceCodester.com for viruses, but new viruses come out every day, so no prevention program can catch 100% of them.

FOR YOUR OWN SAFETY, PLEASE:

1. Re-scan downloaded files using your personal virus checker before using it.
2. NEVER, EVER run compiled files (.exe's, .ocx's, .dll's etc.)--only run source code.

Comments

i am comming soon

working on my local computer, but after i upload on web hosting the program is not working

Nice code but even without login you can go to home.php and see that login is successful. Bit strange.

Add new comment