Maison >développement back-end >tutoriel php >Comment développer une plateforme d'apprentissage en ligne en utilisant PHP et CGI

Comment développer une plateforme d'apprentissage en ligne en utilisant PHP et CGI

PHPz
PHPzoriginal
2023-07-23 08:13:541521parcourir

Comment utiliser PHP et CGI pour développer une plateforme d'apprentissage en ligne

Introduction :
Ces dernières années, avec le développement rapide d'Internet, les plateformes d'apprentissage en ligne sont devenues le premier choix pour de nombreuses personnes pour acquérir des connaissances. Lors du développement d’une plateforme d’apprentissage en ligne efficace et stable, les technologies PHP et CGI sont largement utilisées. Cet article présentera comment utiliser PHP et CGI pour développer une plateforme d'apprentissage en ligne et donnera des exemples de code correspondants.

1. Préparation
Avant de commencer, vous devez préparer les outils suivants :

  1. Un ordinateur avec un serveur Web installé, tel qu'Apache ou Nginx
  2. Un environnement de développement PHP, tel que PHPstorm ou Sublime Text ; Quelques connaissances de base en conception Web et syntaxe de base HTML, CSS et JavaScript.
  3. 2. Utilisez PHP pour créer un système de connexion utilisateur

Créer une base de données
    Tout d'abord, nous devons créer une base de données pour stocker les informations utilisateur, comme MySQL. Créez une base de données nommée "user" en utilisant le code suivant :

  1. CREATE DATABASE user ;

Create user table
    Dans la base de données "user", créez une table nommée "users" pour stocker les informations utilisateur. Le tableau peut contenir les champs suivants : identifiant, nom d'utilisateur, mot de passe, etc. Créez une table nommée "users" en utilisant le code suivant :

  1. CREATE TABLE users (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,

username VARCHAR(30) NOT NULL,
password VARCHAR(30) NOT NULL
) ;

Créer une page d'enregistrement d'utilisateur
    En PHP, nous pouvons utiliser des formulaires HTML pour créer une page d'enregistrement d'utilisateur. Exemple de code :

  1. <!DOCTYPE html>
    <html>
    <head>
    <title>用户注册</title>
    <style>
    label, input {
    display: block;
    margin-bottom: 10px;
    }
    </style>
    </head>
    <body>
    <form action="register.php" method="POST">
    <label for="username">用户名:</label>
    <input type="text" id="username" name="username" required>
    <label for="password">密码:</label>
    <input type="password" id="password" name="password" required>
    <input type="submit" value="注册">
    </form>
    </body>
    </html>
Créer une logique d'enregistrement d'utilisateur
    Dans le fichier register.php, nous pouvons traiter les données d'enregistrement soumises par l'utilisateur et les insérer dans la table des utilisateurs. Exemple de code :

  1. <?php
    $servername = "localhost";
    $username = "root";
    $password = "";
    $dbname = "user";
    
    // 创建数据库连接
    $conn = new mysqli($servername, $username, $password, $dbname);
    
    // 检查连接是否成功
    if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
    }
    
    // 获取表单提交的用户名和密码
    $username = $_POST['username'];
    $password = $_POST['password'];
    
    // 将用户名和加密后的密码插入到users表中
    $sql = "INSERT INTO users (username, password) VALUES ('$username', md5('$password'))";
    
    if ($conn->query($sql) === TRUE) {
    echo "注册成功!";
    } else {
    echo "Error: " . $sql . "<br>" . $conn->error;
    }
    
    // 关闭数据库连接
    $conn->close();
    ?>
Créer une page de connexion utilisateur
    En PHP, nous pouvons utiliser des formulaires HTML pour créer une page de connexion utilisateur. Exemple de code :

  1. <!DOCTYPE html>
    <html>
    <head>
    <title>用户登录</title>
    <style>
    label, input {
    display: block;
    margin-bottom: 10px;
    }
    </style>
    </head>
    <body>
    <form action="login.php" method="POST">
    <label for="username">用户名:</label>
    <input type="text" id="username" name="username" required>
    <label for="password">密码:</label>
    <input type="password" id="password" name="password" required>
    <input type="submit" value="登录">
    </form>
    </body>
    </html>
Créer une logique de connexion utilisateur
    Dans le fichier login.php, nous pouvons traiter les données de connexion soumises par l'utilisateur et les comparer avec les données de la table utilisateur. Exemple de code :

  1. <?php
    $servername = "localhost";
    $username = "root";
    $password = "";
    $dbname = "user";
    
    // 创建数据库连接
    $conn = new mysqli($servername, $username, $password, $dbname);
    
    // 检查连接是否成功
    if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
    }
    
    // 获取表单提交的用户名和密码
    $username = $_POST['username'];
    $password = $_POST['password'];
    
    // 从users表中查询匹配的用户名和密码数据
    $sql = "SELECT * FROM users WHERE username='$username' AND password=md5('$password')";
    $result = $conn->query($sql);
    
    // 判断用户名和密码是否匹配
    if ($result->num_rows > 0) {
    echo "登录成功!";
    } else {
    echo "登录失败!";
    }
    
    // 关闭数据库连接
    $conn->close();
    ?>
  2. 3. Utilisez CGI pour créer un système de gestion de cours

Créez un horaire de cours
    Dans la base de données "utilisateur", créez une table nommée "cours" pour stocker les informations sur les cours. Le tableau peut contenir les champs suivants : id, course_name, professeur, etc. Créez une table nommée "courses" en utilisant le code suivant :

  1. CREATE TABLE courses (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,

course_name VARCHAR(30) NOT NULL,
teacher VARCHAR(30) NOT NULL
) ;

Créer une page de liste de cours
    En PHP, nous pouvons utiliser CGI pour générer du contenu dynamique. Créez un fichier nommé "courses.cgi" pour générer la page de liste des cours. Exemple de code :

  1. #!/usr/bin/perl
    
    use strict;
    use warnings;
    use CGI;
    
    # 创建CGI对象
    my $cgi = CGI->new;
    
    # 创建数据库连接
    my $servername = "localhost";
    my $username = "root";
    my $password = "";
    my $dbname = "user";
    
    # 检查连接是否成功
    my $dbh = DBI->connect("dbi:mysql:$dbname", $username, $password)
    or die "无法连接到数据库: $DBI::errstr";
    
    # 查询courses表中的数据
    my $sth = $dbh->prepare("SELECT * FROM courses");
    $sth->execute();
    
    # 生成课程列表
    my $html = "";
    while (my @row = $sth->fetchrow_array) {
    $html .= "<li>$row[1] - $row[2]</li>";
    }
    
    # 输出HTML页面
    print $cgi->header(-charset=>'UTF-8');
    print <<EOF;
    <!DOCTYPE html>
    <html>
    <head>
    <title>课程列表</title>
    </head>
    <body>
    <h1>课程列表</h1>
    <ul>
    $html
    </ul>
    </body>
    </html>
    EOF
    
    # 关闭数据库连接
    $dbh->disconnect;
Configuration de CGI sur le serveur Web
    Pour activer CGI sur le serveur Web, nous devons définir les options correspondantes dans le fichier de configuration. Par exemple, sur le serveur Apache, nous pouvons éditer le fichier httpd.conf et ajouter les lignes de code suivantes à la fin du fichier :

  1. <Directory "/usr/local/apache2/cgi-bin">
    AllowOverride None
    Options +ExecCGI
    AddHandler cgi-script .cgi .pl
    Require all granted
    </Directory>
  2. IV Résumé
Cet article présente comment utiliser PHP et CGI pour développer un. plate-forme d'apprentissage en ligne et des exemples de code correspondants sont fournis. En créant un système de connexion utilisateur et un système de gestion de cours, nous pouvons créer une plateforme d'apprentissage en ligne entièrement fonctionnelle. J'espère que cet article pourra vous aider à mieux comprendre l'application de PHP et CGI et fournir une référence pour le développement de votre projet.


Remarque : les exemples de code ci-dessus sont uniquement à des fins de démonstration, et davantage de mesures de sécurité et de gestion des erreurs sont requises dans les applications réelles.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn