


How to use PHP and email verification to implement a secure login and registration system?
How to use PHP and email verification to implement a secure login and registration system?
With the development of the Internet, more and more information and services require users to log in to access. In order to ensure user security, we can implement a secure login and registration system through email verification. This article will introduce how to implement such a system using PHP and email verification.
1. Implementation of registration function
- Create database and tables
First, we need to create a database named "users" and add it in Create a table named "users". The structure of the table is as follows:
CREATE TABLE users
(
id
int(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
username
varchar(255) NOT NULL,
email
varchar(255) NOT NULL,
password
varchar(255) NOT NULL,
code
varchar(255) NOT NULL,
active
tinyint(1) NOT NULL DEFAULT '0'
);
- Registration page
Create a page named "register.php", which is used to display the registration form for users to fill in.
<form method="post" action=""> <input type="text" name="username" placeholder="用户名" required><br> <input type="email" name="email" placeholder="邮箱" required><br> <input type="password" name="password" placeholder="密码" required><br> <input type="submit" name="register" value="注册"> </form>
- Registration logic
Add the following PHP code in the "register.php" page to handle the user's registration request.
if (isset($_POST['register'])) { $username = $_POST['username']; $email = $_POST['email']; $password = $_POST['password']; $code = md5(uniqid(rand())); $insert_query = "INSERT INTO users (username, email, password, code) VALUES ('$username', '$email', '$password', '$code')"; mysqli_query($connection, $insert_query); $to = $email; $subject = "验证您的邮箱"; $message = "点击以下链接验证您的邮箱: "; $message .= "https://example.com/verify.php?email=$email&code=$code"; $headers = "From: example@example.com"; mail($to, $subject, $message, $headers); echo "请检查您的邮箱以完成注册。"; }
The above code will insert the registration information filled in by the user into the database, generate a unique verification code, and send it to the user via email for verification.
2. Implementation of the login function
- Login page
Create a page named "login.php", which is used to display the login The form is filled out by the user.
<form method="post" action=""> <input type="email" name="email" placeholder="邮箱" required><br> <input type="password" name="password" placeholder="密码" required><br> <input type="submit" name="login" value="登录"> </form>
- Login logic
Add the following PHP code in the "login.php" page to handle the user's login request.
if (isset($_POST['login'])) { $email = $_POST['email']; $password = $_POST['password']; $login_query = "SELECT * FROM users WHERE email='$email' AND password='$password' AND active='1'"; $result = mysqli_query($connection, $login_query); if (mysqli_num_rows($result) == 1) { echo "登录成功!"; } else { echo "登录失败,请检查您的邮箱和密码。"; } }
The above code will query the database to see if there is a user matching the email address and password filled in by the user, and the user's account has been verified by email.
3. Implementation of email verification function
- Verification page
Create a page named "verify.php", which is used for verification The user's email address.
<?php $email = $_GET['email']; $code = $_GET['code']; $update_query = "UPDATE users SET active='1' WHERE email='$email' AND code='$code'"; mysqli_query($connection, $update_query); echo "您的邮箱已通过验证,现在可以登录了!"; ?>
The above code will update the "active" field of the corresponding user column in the database to 1, indicating that the email has been verified.
Through the above steps, we have implemented a safe and reliable login and registration system. Users need to fill in the correct email address when registering, and verify by clicking on the link in the email to complete the registration. When logging in, it will also be checked whether the user's email has been verified. This method can effectively prevent malicious registration and login operations and improve system security.
The above is the method and sample code introduced in this article to implement a secure login and registration system using PHP and email verification. Hope this helps!
The above is the detailed content of How to use PHP and email verification to implement a secure login and registration system?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Working with database in CakePHP is very easy. We will understand the CRUD (Create, Read, Update, Delete) operations in this chapter.
