Home  >  Article  >  Backend Development  >  PHP implements user login verification code and security functions in the knowledge question and answer website.

PHP implements user login verification code and security functions in the knowledge question and answer website.

王林
王林Original
2023-07-02 21:41:191158browse

PHP implements user login verification code and security functions in knowledge question and answer websites

With the development of the Internet, more and more knowledge question and answer websites appear in our lives. In order to ensure the security of user information and prevent malicious behaviors, user login verification codes and security functions have become very important. This article will introduce how to use PHP to implement user login verification code and security functions in the knowledge question and answer website.

1. User login verification code

1. Generate verification code
User login verification code is a graphical verification code used to verify the user's identity. We can use PHP's GD library to generate verification code images. The following is a simple sample code for generating a verification code:

<?php
session_start();

$width = 130;
$height = 40;
$length = 4;

$code = '';
$chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$chars_length = strlen($chars);

for ($i = 0; $i < $length; $i++) {
    $code .= $chars[rand(0, $chars_length - 1)];
}

$_SESSION['code'] = $code;

$image = imagecreatetruecolor($width, $height);
$background_color = imagecolorallocate($image, 255, 255, 255);
$text_color = imagecolorallocate($image, 0, 0, 0);

imagefilledrectangle($image, 0, 0, $width, $height, $background_color);
imagettftext($image, 20, 0, 10, 28, $text_color, 'arial.ttf', $code);

header('Content-type: image/png');
imagepng($image);
imagedestroy($image);
?>

2. Verification verification code
When the user submits the login form, we need to verify whether the verification code entered by the user is correct. The following is a simple sample code for verification code verification:

<?php
session_start();

$submitted_code = $_POST['code'];
$stored_code = $_SESSION['code'];

if ($submitted_code == $stored_code) {
    // 验证码匹配成功
    // 执行登录操作
} else {
    // 验证码匹配失败
    // 返回错误信息
}
?>

2. User login security function

In addition to the verification code, other security functions can also be used to protect user login information Safety.

1. Password encryption
When storing the user's password, it should be encrypted using a hash function to protect the security of the user's password. The following is a sample code that uses PHP's password_hash function to encrypt a password:

<?php
$password = $_POST['password'];

$hash = password_hash($password, PASSWORD_DEFAULT);

// 将$hash存储到数据库的密码字段中
?>

2. Prevent SQL injection
In the user login system, the information entered by the user must be filtered and verified to prevent SQL injection attack. The following is a simple example code that uses PHP's mysqli_real_escape_string function to prevent injection processing of user-entered information:

<?php
$username = $_POST['username'];
$password = $_POST['password'];

$username = mysqli_real_escape_string($conn, $username);
$password = mysqli_real_escape_string($conn, $password);

// 执行SQL查询
?>

3. Limit the number of login attempts
In order to prevent brute force cracking of passwords, you can set the number of login attempts limit. If a user fails to log in more than a certain number of times, the user account can be locked for a period of time. The following is a simple example code that uses PHP's session mechanism to limit the number of login attempts:

<?php
session_start();

$username = $_POST['username'];
$password = $_POST['password'];

// 检查登录尝试次数
if (isset($_SESSION['login_attempts'])) {
    $_SESSION['login_attempts'] += 1;
} else {
    $_SESSION['login_attempts'] = 1;
}

// 检查登录尝试次数是否超过限制
if ($_SESSION['login_attempts'] > 5) {
    // 锁定账号一段时间
    $_SESSION['locked'] = true;
} else {
    // 执行登录操作
}
?>

This article introduces how to use PHP to implement user login verification codes and security functions in a knowledge question and answer website. Through the verification code, you can prevent malicious programs and robots from logging in and ensure the security of user information; through functions such as password encryption, preventing SQL injection, and limiting the number of login attempts, you can increase the security of the system. I hope this article will help you understand and implement user login verification codes and security functions.

The above is the detailed content of PHP implements user login verification code and security functions in the knowledge question and answer website.. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn